abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 19:11 | Nová verze

    Open source RDP (Remote Desktop Protocol) server xrdp (Wikipedie) byl vydán ve verzi 0.10.0. Z novinek je vypíchnuta podpora GFX (Graphic Pipeline Extension). Nová větev řeší také několik bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    Rocky Linux byl vydán v nové stabilní verzi 9.4. Přehled novinek v poznámkách k vydání.

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

    Dellu byla odcizena databáze zákazníků (jméno, adresa, seznam zakoupených produktů) [Customer Care, Bleeping Computer].

    Ladislav Hagara | Komentářů: 9
    včera 21:11 | Zajímavý článek

    V lednu byl otevřen editor kódů Zed od autorů editoru Atom a Tree-sitter. Tenkrát běžel pouze na macOS. Byl napevno svázán s Metalem. Situace se ale postupně mění. V aktuálním příspěvku Kdy Zed na Linuxu? na blogu Zedu vývojáři popisují aktuální stav. Blíží se alfa verze.

    Ladislav Hagara | Komentářů: 21
    včera 14:33 | Pozvánky

    O víkendu 11. a 12. května lze navštívit Maker Faire Prague, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    8.5. 21:55 | Nová verze

    Byl vydán Fedora Asahi Remix 40, tj. linuxová distribuce pro Apple Silicon vycházející z Fedora Linuxu 40.

    Ladislav Hagara | Komentářů: 19
    8.5. 20:22 | IT novinky

    Představena byla služba Raspberry Pi Connect usnadňující vzdálený grafický přístup k vašim Raspberry Pi z webového prohlížeče. Odkudkoli. Zdarma. Zatím v beta verzi. Detaily v dokumentaci.

    Ladislav Hagara | Komentářů: 6
    8.5. 12:55 | Nová verze

    Byla vydána verze R14.1.2 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.

    JZD | Komentářů: 0
    7.5. 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 10
    7.5. 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 5
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (62%)
     (8%)
     (13%)
     (16%)
    Celkem 149 hlasů
     Komentářů: 11, poslední dnes 18:00
    Rozcestník

    Dotaz: Script na killovani procesu uzivatele, killuje sam sebe.

    25.4.2016 13:55 Imbusilis
    Script na killovani procesu uzivatele, killuje sam sebe.
    Přečteno: 421×
    Dobry den, udelal jsem si script, ktery grepuje a killuje vsechny pocesy uzivatele foo. Rekneme, ze na serveru bezi aplikace take pod uzivatelem foo, script si vezme pidy a pokilluje aplikace. Problem je ten, ze skript musi bezet pod uzivatelem foo, roota nedostanu a instalace dalsich aplikaci je zakazana. Takze grepuji takto:
    ps --no-headers -u foo | grep -v grep | grep -v ps | grep -v awk | grep -v sshd | grep -v bash | grep -v watch | awk ' { print $1}'
    V procesu jsou dalsi procedury, ktere samozrejme vytvari dalsi procesy pod uzivatelem foo a ja si je tak zaroven pokilluji. Existuje nejaky postup, ktery by tomuto predesel? Treba zaznamenat cas spusteni scriptu a pote negrepovat nove vznikle procesy? Necham si poradit. Diky

    Odpovědi

    Josef Kufner avatar 25.4.2016 14:11 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    Takto spuštěné procesy by měly mít správná ID rodičů, takže můžeš sestavit strom procesů a vyhnout se sobě. Jednodušší ale bude napsat si skript v něčem lepším než je shell a kontrolovat pak jen své PID. A nebo prostě jen použít pgrep nebo pkill.

    Řekl bych však, že řešíš původní problém nevhodným způsobem. Pokud jde o hlídaní běžící služby, máme na to systemd a další supervizory (záměrně nepíšu "init" a ano, jde to spustit i pod běžným uživatelem).
    Hello world ! Segmentation fault (core dumped)
    25.4.2016 14:24 Imbusilis
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    Nejde o to resit to takto, je potreba vyhledat vsechny procesy uzivatele foo, krome tech procesu, ktere vznikly pustenim scriptu + plus procesy jak sshd. Jedna se o nekolik aplikaci a nepotrebuji je mit monitorovane pres supervizord, nebo jine. Navic procesy z toho scriptu se mi vytvareji s rodicovskym pid 1... ?:{
    25.4.2016 14:12 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    Asi bych se nejdříve podíval na pgrep a pkill.
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    25.4.2016 17:05 VM
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    Neco jako "killall -u foo" ?

    "A killall process never kills itself (but may kill other killall processes)."
    26.4.2016 12:58 Imbusilis
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    prekvapive mujpid=$$ na druhem radku scriptu a protom grep -v $mujpid zafungoval..
    27.4.2016 09:06 hejkal
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    S temi grepy to je ovsem cele ptakovina, protoze procesy, ktere chces killnout, mohou klidne mit s nimi shodu. Tedy jako pomucka pri interaktivni praci mozna (pak si to zkontroluju), pro automatizaci nesmysl, obzvlast pokud na vysledku zalezi (tedy neni to domaci server na hrani apod.).
    26.4.2016 16:28 Bill Gates
    Rozbalit Rozbalit vše Re: Script na killovani procesu uzivatele, killuje sam sebe.
    Moznosti muze byt treba to, ze si pro ty dalsi spoustene procesy pridate nejaky specificky parametr jako "tag", treba:

    podporces.sh -nokillme123456 -param1=value1 -param2=value2 ...

    Tyto podporcesy pote vyfiltrovat pomoci grep -v nokillme123456. 123456 muze byt treba PID procesu, ktery je puvodnim spoustecem, aby bylo jasno, ze tyhle podprocesy patri nam a nemaji se killovat. Samozrejme u podporcesu, kde by takovyto "tag" parametr zpusobil problem s tim, ze by dany proces parametru nerozumel a skoncil by chybou to logicky nepujde pouzit.

    Ja to takhle u jedne veci uspesne pouzivam, kde si z PHP scriptu v roli ridiciho scriptu volam podprocesy a ruzne monitoruju jejich beh, pripadne pokud jejich pocet soucasne s vytizenim CPU klesne pod urcity limit, spoustim dalsi, nebo je muzu killnout.

    Jde o to je nejak identifikovat. V takovem pripade je potreba pouzit "ps ax" coz vraci i parametry procesu.

    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.