Portál AbcLinuxu, 11. května 2025 09:58
Ahoj.
Když pustím:
sh -c 'yes'
a pošlu SIGTERM právě spuštěnému shellu, sh i yes skončí.
Když pustím:
sh -c 'yes | sed "s/y/n/"'
a pošlu SIGTERM právě spuštěnému shellu, sh skončí, ale yes a sed zůstanou běžet (init se stane předkem).
Proč?
V bash manpage je napsáno, že pokud je shell interaktivní a dostane SIGHUP, přepošle ho všem potomkům a počká na ně než se ukončí. Je možné dosáhnout něčeho podobného (tj. ukončit processy, které pod ním běží, když dostane nějaký signál, např. TERM) když je shell neinteraktivní (tj. když ho spustím s parametrem -c).
Děkuju za pomoc.
Proč?Neručím za to, že to vysvětluji správně - větší znalci mě snad opraví
sh -c 'yes'tak
sh
provede rovnou exec()
a yes
je tedy potomkem interaktivního shelu a tudíž dostane hezky ten signál přeposlaný.
Pokud se ale spustí
sh -c 'yes | sed "s/y/n/"'tak se musí vytvořit subshell (jsou nutné 2×
fork()
a 2× exec()
) a ten už je neinteraktivní a signály asi ignoruje.
Jak se tomu vyhnout mě ale nenapadá.
Diky, to je ono (v prvnim pripade v `ps -f' opravdu zadny sh neni, v druhem ano).
Ten neinteraktivni shell signaly neignoruje, ale jenom nepokilluje potomky (coz je asi spravne, ale ted mi to zrovna nevyhovuje).
Muzete poslat signal cele skupine procesu, to zabije nejenom sh -c ale i jeho potomky. To se dela tak, ze prikazu kill predate zaporny PID. Napr., pokud PID procesu sh -c je 1234, pak kill -9 -1234 zabije i 'yes | sed'.
trap
, kterým definuješ akce, které se mají provést po obdržení specifického signálu.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.