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ářů: 3
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ářů: 26
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 332 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    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: 272×
    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.