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 | Komunita

    Ubuntu 26.04 LTS bude (𝕏) Resolute Raccoon (rezolutní mýval).

    Ladislav Hagara | Komentářů: 0
    včera 21:00 | Nová verze

    Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    včera 20:11 | Komunita

    Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Nová verze

    Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | IT novinky

    Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Nová verze Ladislav Hagara | Komentářů: 0
    5.10. 20:00 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy z konference LinuxDays 2025.

    Ladislav Hagara | Komentářů: 0
    4.10. 15:22 | IT novinky

    Na konferenci LinuxDays 2025 byl oficiálně představen nový router Turris Omnia NG.

    Ladislav Hagara | Komentářů: 34
    4.10. 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 16
    3.10. 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 10
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (45%)
     (15%)
     (17%)
     (22%)
     (15%)
     (18%)
     (16%)
     (15%)
    Celkem 181 hlasů
     Komentářů: 12, poslední 4.10. 20:35
    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: 468×
    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.