abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:55 | Zajímavý článek

    Uroš Popović v krátkém článku vysvětluje, co jsou emulátor terminálu, TTY a shell a jaké jsou mezi nimi rozdíly. Jde o první díl seriálu na jeho novém webu Linux Field Guide věnovaném nízkoúrovňové práci s linuxovými systémy.

    |🇵🇸 | Komentářů: 0
    16.5. 22:33 | Nová verze

    Byl vydán Debian 13.5, tj. pátá opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.14, tj. čtrnáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.5. 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 3
    15.5. 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 1
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 9
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 27
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    13.5. 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1646 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: pid hlavního procesu na pozadí

    12.6.2015 13:04 MilanC | skóre: 16
    pid hlavního procesu na pozadí
    Přečteno: 536×
    Ahoj,

    ve svém skriptu mám následující volání (zjednodušeno, vypuštěné parametry pro encoding...)

    sudo -u $DAEMONUSER ffmpeg -loglevel quiet -i $source -vn ... \ -f mpegts - | sudo -u $DAEMONUSER ffmpeg -loglevel quiet \ -f mpegts -i - -c copy ... $dst $index \ -f mpegts -c copy -f mpegts udp://@$udp_dst & echo $! > $PIDFILE

    Podle všeho se mi takto do $PIDFILE uloží číslo až toho podřízeného procesu, úpotřebuji ale toho hlavního, abych to v případě potřeby mohl sestřelit jedním killem komplet.

    Zkoušel jsem to hodit za první ffmpeg, tj. těsně před pajpu dávám & echo $! > $PIDFILE A za celým příkazem jsem nechal & (zkoušeno i bez), výsledkem je vypisování non ASCII znaků do konzole. Nemůžu na to přijít. :(

    Děkuji.


    Řešení dotazu:


    Odpovědi

    12.6.2015 13:18 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ještě jednou pro lepší čitelnost...
    sudo -u $DAEMONUSER ffmpeg -loglevel quiet -i $source -vn ... \
     -f mpegts - | sudo -u $DAEMONUSER ffmpeg -loglevel quiet \
     -f mpegts -i - -c copy ... $dst $index \
     -f mpegts -c copy -f mpegts udp://@$udp_dst & echo $! > $PIDFILE
    
    13.6.2015 13:56 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Hádám, že to sestřelí jen poslední ffmpeg a předchozí běží vesele dál. Pokud používáte bash, pak by mohlo být řešením

    ${PIPESTATUS[@]}

    což vám vrátí všechny PID procesů, které jsou spojené rourou. Ty pak pozabíjíte jedním killnutím.

    Bez bashe je zjištění všech PID složitější -- vyžaduje větší znalost file deskriptorů. Přičemž bude takové řešení výrazně nepřehlednější (pokud to má být stále one-liner). Další způsob (méně spolehlivý) je: zjistit poslední PID pomocí !$ (tak jak to máte) a pomocí utilitky ps a programu awk nebo sed si vytáhnout všechny PID u stejného subprocesu.
    13.6.2015 14:01 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Beru zpět. ${PIPESTATUS[@]} vám vrátí jen status 0 1 a ne PID. Tím to tedy nepůjde.
    13.6.2015 14:19 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Tady jsou různá řešení. Řešení 4 je ono zmíněné s file deskriptory, které byste mohl použít jako one-liner.
    13.6.2015 14:31 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    V bashi použijte ${PIPEPID[@]}. Já věděl že něco takového musí existovat, jen jsem to zaměnil za ${PIPESTATUS[@]} . Takže tak ;).
    15.6.2015 13:05 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ahoj, zní to zajímavě, ale nedohledal jsem žádný ukázkový příklad a sám vůlbec nevím jak na to. Mimochodem, nestačilo by ukládat pid toho prvního procesu? Předpokládám, že po jeho sestřelení se zabije i ten další co visí na té pajpě? Jde o init skript. Díky.
    15.6.2015 13:08 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Jde mi také o to jak to řešit, jestli do pid file "nějak" uložit všechny ty pidy pod sebe? Aby pak na to šel zavolat kill.
    15.6.2015 14:52 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ahoj, zní to zajímavě, ale nedohledal jsem žádný ukázkový příklad

    Když on ${PIPEPID[n]} skutečně neexistuje, jak tak znovu na to koukám s otevřeným manuálem. Takhle to tedy nepůjde. ${PIPESTATUS[n]} existuje, ale ten vám nepomůže. Takže si jedině pohrát s file deskriptory.
    Tohle není běžné chování. Normálně při ukončení programu za rourou se posílá signál SIGPIPE a ten ukončí proces, který do pipe zapisuje. Proč to tak u ffmpeg není netuším. Zkusit zabít jen první by také stálo za zkoušku, ale k tomu si stejně musíte nějak vytáhnout pid prvního.
    15.6.2015 16:16 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ještě než se pustíte do zabíjení separé, můžete zkusit zabalit vše do dalšího subshellu. Pokud zabijete tento subshell, mělo by to ukončit všechny jeho dítka. Jediné co musíte provést je, že výraz dáte do závorek:

    ( ffmpeg..|ffmpeg.. )& echo $!

    Nevím proč mi to nenapadlo dřív :).
    16.6.2015 10:01 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ahoj,

    zkusil jsem to ozávorkovat. Takto to do pid souboru uloží pid toho init skriptu.
    # cat /var/run/ffmpeg/109.pid
    28767
    
    28767 ?        S      0:00 /bin/sh /etc/init.d/ffmpeg-hls-restream start
    
    Vypadá to takto:
    28767 ?        S      0:00 /bin/sh /etc/init.d/ffmpeg-hls-restream start
    28768 ?        S      0:00  \_ sudo -u vlc /usr/local/bin/ffmpeg -loglevel quiet -i udp://@...
    28769 ?        S      0:00  \_ /usr/local/bin/ffmpeg -loglevel quiet -f mpegts -i - -c copy ...
    
    Po killu 28767 zmizí jen ten jeden řádek, ale ty ffmpegy si žijou dál. Divný. :(
    16.6.2015 10:31 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Nepomohlo by kill -9 28767 ?
    16.6.2015 10:37 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Dělám to v podstatě tak.

    start-stop-daemon --stop --signal 9 --oknodo --pidfile "$PIDFILE" --exec /usr/local/bin/ffmpeg
    Fuky avatar 16.6.2015 10:57 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Hoď do přílohy celý init.d skript, ať máme kompletní nezkreslené info.
    16.6.2015 11:42 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Tady je: http://devel.chvalsiny.net/init-skript.txt
    Fuky avatar 16.6.2015 13:19 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí

    Předpokládám, že sudo využíváš pouze pro přepnutí na jiného uživatele. Místo sudo bych použil přímo start-stop-daemon a ffmpeg rouru by jsem spouštěl ze skriptu $DAEMON_WRAPPER:

    start-stop-daemon --start --quiet --pidfile $PIDFILE
     --chuid $DAEMONUSER --background --make-pidfile --exec $DAEMON_WRAPPER -- $ARGS
    

    Vše poté zabiješ pomocí:

    pkill -P $(cat $PIDFILE)
    16.6.2015 14:09 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    jj, sudo je jen aby to neběželo pod rootem. Ten pkill tedy místo start-stop-daemon --stop

    Ale to spouštění nějak nechápu, celé to stávající včetně argumentů mám nacpat do $DAEMON_WRAPPER? Nebo to ještě rozdělit do ARGS? Píšeš jen o té rouře, jak potom s tím hlavním ffmpeg procesem? A mám to nechat ozávorkované?

    Sry, já ten start-stop-daemon neznám tak možná úplně nehcápu. Dík
    Fuky avatar 16.6.2015 16:32 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí

    Proměná $ARGS se využívá k předání parametrů skriptu $DAEMON_WRAPPER, je na tobě co všechno mu budeš předávat. Wrapper bude zajišťovat spuštění pouze jedné instace ffmpeg roury, v init.d skriptu máš cyklus for, který postupně spouští X různých instací. Závorky zruš, stejně jako sudo a ukládání PID do PIDFILE na konci roury, to zařídí start-stop-daemon. Pod pojmem "ffmpeg roura" mám na mysli (tj. celou jednu instaci):

    FFMPEG1 PARAM_1 PARAM_N |FFMPEG2 PARAM_2 PARAM_N

    start-stop-daemon zařídí forknutí wrapperu na pozadí, spuštění pod definovaným uživatelem, vytvoření $PIDFILE, kde bude PID právě tohoto forknutého wrapperu, ve kterém budeš spouštět ffmpeg rouru bez přesunu na pozadí (tj. žádný ampersand na konci roury), ffmpeg roura má jako rodiče právě wrapper, takže když pozabíjíš jeho potomky, máš vyřešeno. Ano, uděláš to příkazem pkill místo "start-stop-daemon --stop", protože rodič se ukončí sám, jakmile budou pozabíjeni potomci, protože nedělá nic jiného než, že čeká na jejich dokončení. Na vhodném místě si ještě smaž PIDFILE, třeba v init.d skriptu po pozabíjení potomků. Můžeš jim nejprve poslat SIGTERM, vyčkat, sjistit pomocí pgrep zda-li ještě potomci běží a případně jim poslat SIGKILL, pokud budou běžet i po uplynutí definované doby.

    $ man start-stop-daemon
    16.6.2015 17:14 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    zajímavé, třeba se k těmto výšinám na úrovni init.d také jednou dostanu :). Musím si to někam poznamenat.
    17.6.2015 11:51 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Ahoj, dost se s tím peru, ale zatím bez úspěchu.

    Mít vše včetně argumentů v DAEMON_WRAPPER nejde, vždy první parametr křičí jako ilegal. Tak jsem to trhnul - DAEMON_WRAPPER=binárka a vše ostatní do ARGS.

    Dal jsem si echo a když to nakopčim do řádku tak to jede ok. Nicméně když to spouští init skript, tak se sice ffmpeg pokouší nahodit, ale hned se ukončí/popadá.

    DAEMON_WRAPPER /usr/local/bin/ffmpeg ARGS: -i udp://@239.7.0.109:1234 ... -f mpegts - | /usr/local/bin/ffmpeg -f mpegts -i - -c copy -f mpegts -c copy -f mpegts udp://@239.7.1.109:1234

    Aktuální skript po úpravě: http://devel.chvalsiny.net/init-skript2.txt

    Děkuji.
    Fuky avatar 17.6.2015 14:25 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí

    Ne, takto jsem to vůbec nemyslel. Psal jsem, ať si uděláš skript $DAEMON_WRAPPER, do kterého vložíš spouštění ffmpeg a případné potřebné argumenty mu předáš pomocí proměné $ARG. Možná ti níže uvedený fragment pomůže v pochopení jak jsem to myslel.

    # vim init.d/ffmpeg-hls-restream
    ...
    DAEMON_WRAPPER=/usr/local/bin/ffmpeg_wrapper.sh
    ...
    do_start() {
    ...
        start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid $DAEMONUSER --background --make-pidfile --exec $DAEMON_WRAPPER -- $ARGS
    ...
    do_stop() {
    ...
        pkill -P $(cat $PIDFILE)
    ...
    
    # vim /usr/local/bin/ffmpeg_wrapper.sh
    ...
            if [ $vcodec ]; then
                /usr/local/bin/ffmpeg -loglevel quiet -i $source -flags -global_header -profile:v baseline -c:v $vcodec -b:v $bitrate -maxrate $vbvmaxrate -bufsize $vbvbufsize \
                 -deinterlace -vf "crop=in_w$vcrop:in_h$vcrop,scale=$width:$height" -keyint_min $keyint_min -g $gop -c:a $acodec -b:a $abitrate -ar $asrate \
                 -f mpegts - | /usr/local/bin/ffmpeg -loglevel quiet \
                 -f mpegts -i - -c copy -hls_time $seglen -hls_list_size $numsegs -hls_base_url $index_url -hls_flags delete_segments -hls_segment_filename $dst $index \
                 -f mpegts -c copy -f mpegts udp://@$udp_dst
    ...
    
    17.6.2015 15:58 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Tak jasné, už jsem pochopil pointu. :-) Funguje to perfektně, děkuji moc!
    16.6.2015 10:49 RM
    Rozbalit Rozbalit vše Re: pid hlavního procesu na pozadí
    Jinak jestli chcete vytáhnout všechny pid a zkusit je pozabíjet separé, pak : ffmpeg ... | ffmpeg .... | ffmpeg ... & ps -o "%p %c" --no-headers --ppid $$ | sed -n '/ffmpeg\|vlc/{s/ffmpeg//;s/vlc//;p}' | tr -d '\n' > pid.txt Řešení s file deskriptory bych vám také mohl nabídnout, ale jelikož to máte stejně ve skriptu, který spouštíte (tj. máte rodiče a jeho pid se nechá získat pomocí $$), není nutné to hned hrotit :); tohle by mělo vrátit co potřebujete. Stačit by mělo už jen kill -9 $(cat pid.txt).

    á propós, máte vůbec práva k tomu tyhle procesy zabít ;). Vidím tam všude sudo. Nestačilo by tedy se stávajícím sudo kill ...

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.