ZOBRAZENÍ - SIGHUP
Na POSIX -kompatibilní platformy, ZOBRAZENÍ ("signal hang nahoru") je signál posláno do a proces když je jeho ovládací terminál uzavřen. (Původně byl navržen tak, aby oznamoval proces a sériová linka pokles.) SIGHUP je a symbolická konstanta definované v hlavičkový soubor signál.h
.
Dějiny
Přístup k počítačové systémy po mnoho let spočívalo v připojení a terminál do sálového systému přes sériovou linku a RS-232 protokol. Z tohoto důvodu, když systém softwaru přerušení, zvané signály, byly vyvíjeny, byl určen signál pro použití na „Hangup“.
SIGHUP bude odeslán na programy při přerušení sériové linky, často proto, že připojený uživatel ukončil připojení zavěšením modemu. Systém by zjistil, že linka byla zrušena prostřednictvím ztracených Detekce datového nosiče (DCD) signál.
Signály byly vždy pohodlnou metodou meziprocesová komunikace (IPC), ale v raných implementacích nebyly žádné uživatelem definované signály (například pozdější dodatky SIGUSR1 a SIGUSR2 ), které programy mohly zachytit a interpretovat pro své vlastní účely. Z tohoto důvodu aplikace, které nevyžadovaly řídicí terminál, jako např démoni, by znovu určil SIGHUP jako signál k opětovnému čtení konfigurační soubory nebo znovu inicializovat. Tato konvence přežívá dodnes v balíčcích jako Apache a Poslat mail.
Moderní využití
S poklesem přístupu přes sériovou linku se význam SIGHUP u moderních systémů poněkud změnil, což často znamená ovládání pseudo nebo virtuální terminál Byl zavřen. Pokud je příkaz spuštěn uvnitř okna terminálu a okno terminálu je zavřeno, zatímco proces příkazu je stále spuštěn, obdrží SIGHUP.[1]
Pokud je proces přijímající SIGHUP a Unix shell, pak jako součást kontrola práce často zachytí signál a zajistí, aby všechny zastavené procesy pokračovaly před odesláním signálu podřízeným procesům (přesněji skupiny procesů, který je interně reprezentován shellem jako „úloha“), která je standardně ukončuje.[2]
To lze obejít dvěma způsoby. Za prvé Single UNIX Specification popisuje shell nástroj s názvem nohup, který lze použít jako obálku ke spuštění programu a ve výchozím nastavení ignoruje SIGHUP. Zadruhé, podřízené skupiny procesů lze vyvolat „odmítnutím“ popřít s ID úlohy, která odebere skupinu procesů z tabulky úloh prostředí (takže jim nebude zaslána SIGHUP), nebo (volitelně) je ponechá v tabulce úloh, ale zabrání jim v přijetí SIGHUP při ukončení shellu.
Různé skořápky mají také jiné metody ovládání a správy SIGHUP, například popřít zařízení ksh. Nejmodernější Linuxové distribuce dokumentace specifikovat pomocí zabít -HUP
k odeslání signálu SIGHUP.[3]
Démon programy někdy používají SIGHUP jako signál k restartu, což je nejčastější důvod pro opětovné načtení konfiguračního souboru, který byl změněn.
Detaily
Používají se symbolické názvy signálů, protože čísla signálů se mohou na různých platformách lišit, ale XSI -konformní systémy umožňují použití numerické konstanty 1 k označení SIGHUP, který naprostá většina systémů ve skutečnosti používá.
SIGHUP může být zacházeno. To znamená, programátoři mohou definovat akci, kterou chtějí provést po obdržení SIGHUP, například volání a funkce, ignorování nebo obnovení výchozí akce.
Výchozí akce na POSIX -kompatibilní systémy je neobvyklé ukončení.
Reference
- ^ Kerrisk, Michael, ed. (25. července 2009), „SIGNÁL (7)“, Příručka programátora systému Linux (verze 3.22), Linuxové archivy jádra, vyvoláno 23. září 2009.
- ^ Garrels, Machtelt, ed. (27. prosince 2008), „Signály“, Bash Guide for Beginners, ver. 1.11, Dokumentační projekt Linuxu, vyvoláno 23. září 2009.
- ^ Kerrisk, Michael, ed. (25. července 2009), „ZABIT (2)“, Příručka programátora systému Linux (verze 3.22), Linuxové archivy jádra, vyvoláno 23. září 2009.