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í
×
dnes 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
dnes 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
dnes 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
dnes 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
dnes 00:08 | Pozvánky

V sobotu 18. 2. se v Praze v prostorách VŠE uskuteční od 9:30 již 4. ročník největší české konference o open source redakčním systému WordPress (WP) - WordCamp Praha 2017.

… více »
smíťa | Komentářů: 0
včera 23:58 | Komunita

Kryptoměnová komunita zahájila nový rok spuštěním projektu Blockchain.cz, jehož cílem je kolektivně nalézt ideální překlad pro čím dál frekventovanější slovo „blockchain“. Přispět návrhem může kdokoli. Sběr bude trvat až do konce září 2017. Následně bude probíhat dvoutýdenní veřejné hlasování, které bude zakončeno výběrem toho nejlepšího návrhu.

xHire | Komentářů: 5
včera 15:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno je celkově 270 bezpečnostních chyb. V Oracle Java SE je například opraveno 17 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 16 z nich. V Oracle MySQL je opraveno 27 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 5 z nich.

Ladislav Hagara | Komentářů: 0
včera 02:48 | Nová verze

Po půl roce od vydání verze 9.0 (zprávička) byla vydána verze 10.0 zvukového serveru PulseAudio. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 28
včera 00:33 | Komunita Ladislav Hagara | Komentářů: 8
18.1. 17:30 | Zajímavý článek

Mozilla.cz informuje, že webový prohlížeč Firefox bude od verze 53 obsahovat integrovaný prohlížeč dat ve formátu JSON. Firefox kromě strukturovaného prohlížení nabídne také možnost filtrace a uložení na disk. Dle plánu by měl Firefox 53 vyjít 18. 4. 2017.

Ladislav Hagara | Komentářů: 1
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (11%)
Celkem 333 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    Dotaz: pid hlavního procesu na pozadí

    12.6.2015 13:04 MilanC | skóre: 9
    pid hlavního procesu na pozadí
    Přečteno: 379×
    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: 9
    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: 9
    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: 9
    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: 9
    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: 9
    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: 9
    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: 9
    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: 9
    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.
    Řešení 1× (MilanC (tazatel))
    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: 9
    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.