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 17:44 | Zajímavý článek

    Jak si zobrazit pomocí Chrome a na Chromiu založených webových prohlížečích stránky s neplatným certifikátem? Stačí napsat thisisunsafe.

    Ladislav Hagara | Komentářů: 0
    včera 00:33 | Bezpečnostní upozornění

    V repozitáři AUR (Arch User Repository) linuxové distribuce Arch Linux byly nalezeny a odstraněny tři balíčky s malwarem. Jedná se o librewolf-fix-bin, firefox-patch-bin a zen-browser-patched-bin.

    Ladislav Hagara | Komentářů: 9
    včera 00:22 | Komunita

    Dle plánu by Debian 13 s kódovým názvem Trixie měl vyjít v sobotu 9. srpna.

    Ladislav Hagara | Komentářů: 0
    19.7. 13:22 | Komunita

    Vývoj linuxové distribuce Clear Linux (Wikipedie) vyvíjené společností Intel a optimalizováné pro jejich procesory byl oficiálně ukončen.

    Ladislav Hagara | Komentářů: 1
    18.7. 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    18.7. 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 1
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 4
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 6
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (24%)
     (18%)
     (6%)
     (6%)
     (3%)
     (6%)
     (3%)
     (33%)
    Celkem 33 hlasů
     Komentářů: 4, poslední včera 16:33
    Rozcestník

    Dotaz: PID "vnořeného" procesu v bash

    18.2.2013 14:21 JanM | skóre: 28
    PID "vnořeného" procesu v bash
    Přečteno: 366×
    Dobré odpoledne,

    potřeboval bych elegantně a jednoznačně zjistit PID procesu spuštěného dolphinu (tedy třeba formou PID=$!), tak aby proměnná $PID byla použitelná dále ve skriptu.
    su - $fg_user -c "(DISPLAY=$fg_display setsid dolphin --select ${SCANDIR}${FILENAME}${EXT} &>/dev/null </dev/null &)"
    Momentálně to řeším filtrováním výstupu z ps, ale vzhledem k možným duplicitám názvu procesu to není úplně neprůstřelné řešení. Šlo by to ještě řešit dodatečnou kontrolou PPID, ale to už je trochu drbání se levou rukou za pravým uchem.

    Řešení dotazu:


    Odpovědi

    18.2.2013 14:30 student
    Rozbalit Rozbalit vše Re: PID "vnořeného" procesu v bash

    Skus nieco ako

    DOLPHINPID=`su - $fg_user -c "(DISPLAY=$fg_display setsid dolphin --select ${SCANDIR}${FILENAME}${EXT} &>/dev/null </dev/null & "'echo $!)'`
    echo "$DOLPHINPID"
     
    18.2.2013 18:51 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: PID "vnořeného" procesu v bash
    Naozaj to funguje. Vďaka.

    Chápu to správně, že bash nejprve "vyhodnotí" obsah uzavřený mezi uvozovkami (přičemž mu nevadí, že chybí pravá závorka), znak & kromě "upozaďování" procesu funguje i jako oddělovač mezi příkazy, echo mezi jednoduchými uvozovkami (funguje je to i s dvojitými) zobrazí PID a bash se konečně dočká pravé závorky uzavírající samostatně spouštěnou session?

    Hlava mi trochu nebere to s těmi závorkami...
    18.2.2013 20:35 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: PID "vnořeného" procesu v bash
    Tak jsem to ten komentář trochu uspěchal - výraz echo $! je nutné mít oddělen jednoduchými uvozovkami, jinak to vypíše PID jiného procesu.

    Z toho jsem ještě méně moudrý...
    18.2.2013 22:25 student
    Rozbalit Rozbalit vše Re: PID "vnořeného" procesu v bash

    O oddelovaci prikazov to chapete spravne, echo naozaj spravne vypise pid.

    Prikaz by mozno daval vacsi zmysel, keby bol napisany:

    DOLPHINPID=`su - $fg_user -c "(DISPLAY=$fg_display setsid dolphin --select ${SCANDIR}${FILENAME}${EXT} &>/dev/null </dev/null & echo \$!)"`
    echo "$DOLPHINPID"

    To ostatne je uz iba syntakticky cukor, ako napisat $premennu, ktoru by neinterpretoval vonkajsi shell (=ten, co spusta su). Aby to bolo jasne - shell interpretuje uvodzovky a premenne v nich raz (pri citani su - $fg...) a potom ten vnutorny druhy krat - pri spustani (DISPLAY=$fg_display... . Tie vnutorne zatvorky vyzeraju byt myslene pre vnutorny shell (aj ked ich vyznam mi nedochadza), preto je to vnutornemu shellu jedno - on dostane vysledok.

    Ako ukazka na vysvetlenie mozu sluzit napriklad tieto prikazy

    su - testuser -c 'echo $USER'
    su - testuser -c "echo \$USER"
    su - testuser -c echo\ \$USER
    su - testuser -c "echo $USER"
    AAA='$USER'; su - testuser -c "echo $AAA"

    Prve tri predaju vnutornemu shellu to iste - echo $USER. Stvrty preda echo nasledovane nazvom aktualneho pouzivatela. A nakoniec je fungovanie vidiet na piatom prikaze - tam vonkajsi shell spustajuci su zmeni $AAA na $USER a vnutorny shell interpretuje echo $USER a vypise "testuser".

    19.2.2013 15:43 JanM | skóre: 28
    Rozbalit Rozbalit vše Re: PID "vnořeného" procesu v bash
    Tie vnutorne zatvorky vyzeraju byt myslene pre vnutorny shell (aj ked ich vyznam mi nedochadza), preto je to vnutornemu shellu jedno - on dostane vysledok.
    Však smysl vnitřních závorek je v tomto případě nesmyslný, stejně jako setsid. Obé se tam dostalo během snahy o řešení problému řešeného jinde ve fóru (třetí příspěvek), po jeho vyřešení je oboje zbytečné.

    Nicméně alespoň pro mne velmi poučné, takže ještě jednou děkuji za výklad a příklady.

    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.