SIGHUP: Difference between revisions
Martinkunev (talk | contribs) m the shell won't actually continue stopped jobs |
Martinkunev (talk | contribs) m Undid revision 685856894 by Martinkunev (talk) |
||
Line 15: | Line 15: | ||
With the decline of access via serial line, the meaning of SIGHUP has changed somewhat on modern systems, often meaning a controlling [[Terminal emulator|pseudo or virtual terminal]] has been closed (i.e. a command is executed inside a terminal window and the terminal window is closed while the command process is still running).<ref name="linux-signal7">{{Citation|chapter-url=http://www.kernel.org/doc/man-pages/online/pages/man7/signal.7.html|chapter=SIGNAL(7)|title=[[Linux Programmer's Manual]] (version 3.22)|editor-last=Kerrisk|editor-first=Michael|date=25 July 2009|publisher=The Linux Kernel Archives|accessdate=23 September 2009}}.</ref> |
With the decline of access via serial line, the meaning of SIGHUP has changed somewhat on modern systems, often meaning a controlling [[Terminal emulator|pseudo or virtual terminal]] has been closed (i.e. a command is executed inside a terminal window and the terminal window is closed while the command process is still running).<ref name="linux-signal7">{{Citation|chapter-url=http://www.kernel.org/doc/man-pages/online/pages/man7/signal.7.html|chapter=SIGNAL(7)|title=[[Linux Programmer's Manual]] (version 3.22)|editor-last=Kerrisk|editor-first=Michael|date=25 July 2009|publisher=The Linux Kernel Archives|accessdate=23 September 2009}}.</ref> |
||
If the program receiving SIGHUP is a [[Unix shell]], it will often intercept the signal and |
If the program receiving SIGHUP is a [[Unix shell]], it will often intercept the signal and ensure all stopped programs are continued before sending the signal to child jobs.<ref name="bash-beg">{{Citation|editor-last=Garrels|editor-first=Machtelt|title=Bash Guide for Beginners, ver. 1.11|chapter=Signals|date=27 December 2008|chapter-url=http://tldp.org/LDP/Bash-Beginners-Guide/html/sect_12_01.html|publisher=[[The Linux Documentation Project]]|accessdate=23 September 2009}}.</ref> |
||
The [[Single UNIX Specification]] describes a shell utility called [[nohup]], which can be used as a wrapper to start a program and make it immune to SIGHUP. |
The [[Single UNIX Specification]] describes a shell utility called [[nohup]], which can be used as a wrapper to start a program and make it immune to SIGHUP. |
Revision as of 12:42, 15 October 2015
On POSIX-compliant platforms, SIGHUP is a signal sent to a process when its controlling terminal is closed. (It was originally designed to notify the process of a serial line drop). SIGHUP is a symbolic constant defined in the header file signal.h
.
Etymology
SIG is a common prefix for signal names; HUP is a contraction of hang up.
History
Access to computer systems for many years consisted of connecting a terminal to a mainframe system via a serial line and the RS-232 protocol. For this reason, when a system of software interrupts, called signals, were being developed, a signal was designated for use on "Hangup".
SIGHUP would be sent to programs when the serial line was dropped, often because the connected user terminated the connection by hanging up the modem. The system would detect the line was dropped via the lost DCD "carrier detect" signal.
Signals have always been a convenient method of inter-process communication (IPC), but in early implementations there were no user-definable signals (such as the later additions of SIGUSR1 and SIGUSR2) that programs could intercept and interpret for their own purposes. For this reason, applications that did not require a controlling terminal, such as daemons, would re-purpose SIGHUP as a signal to re-read configuration files, or reinitialize. This convention survives to this day in packages such as Apache and Sendmail.
Modern usage
With the decline of access via serial line, the meaning of SIGHUP has changed somewhat on modern systems, often meaning a controlling pseudo or virtual terminal has been closed (i.e. a command is executed inside a terminal window and the terminal window is closed while the command process is still running).[1]
If the program receiving SIGHUP is a Unix shell, it will often intercept the signal and ensure all stopped programs are continued before sending the signal to child jobs.[2]
The Single UNIX Specification describes a shell utility called nohup, which can be used as a wrapper to start a program and make it immune to SIGHUP.
Different shells also have other methods of controlling and managing SIGHUP, such as the disown facility of GNU bash.[2] Most modern Linux distributions documentation specify using kill -HUP <processID> to send the SIGHUP signal.[3]
Daemon programs sometimes use SIGHUP as a signal to restart themselves, the most common reason for this being to re-read a configuration file that has been changed.
Details
Symbolic signal names are used because signal numbers can vary across platforms, but XSI-conformant systems allow the use of the numeric constant 1 to be used to indicate a SIGHUP, which the vast majority of systems in fact use.
SIGHUP can be handled. That is, programmers can define the action they want to occur upon receiving a SIGHUP, such as calling a function, ignoring it, or restoring the default action.
The default action on POSIX-compliant systems is an abnormal termination.
References
- ^ Kerrisk, Michael, ed. (25 July 2009), "SIGNAL(7)", Linux Programmer's Manual (version 3.22), The Linux Kernel Archives, retrieved 23 September 2009.
- ^ a b Garrels, Machtelt, ed. (27 December 2008), "Signals", Bash Guide for Beginners, ver. 1.11, The Linux Documentation Project, retrieved 23 September 2009.
- ^ Kerrisk, Michael, ed. (25 July 2009), "KILL(2)", Linux Programmer's Manual (version 3.22), The Linux Kernel Archives, retrieved 23 September 2009.