Background process: Difference between revisions
Jon Kolbert (talk | contribs) m Updating links from HTTP→HTTPS for Microsoft TechNet |
Undid revision 1259462169 by Kongpc14567 (talk) not helpful |
||
(28 intermediate revisions by 21 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Computer process that runs behind the scenes}} |
|||
A '''background process''' is a [[Process (computing)|computer process]] that runs ''behind the scenes'' (i.e., in the background) and without user intervention.<ref name="tlt">{{cite web|url= |
A '''background process''' is a [[Process (computing)|computer process]] that runs ''behind the scenes'' (i.e., in the background) and without user intervention.<ref name="tlt">{{cite web|url=http://www.linux-tutorial.info/modules.php?name=MContent&pageid=3|title=What is an Operating System?, Processes|accessdate=14 November 2010|publisher=The Linux Tutorial|archive-date=15 August 2020|archive-url=https://web.archive.org/web/20200815081900/http://www.linux-tutorial.info/modules.php?name=MContent&pageid=3|url-status=dead}}</ref> Typical tasks for these processes include logging, system monitoring, scheduling,<ref>{{cite book|url=http://www.stanford.edu/dept/itss/docs/oracle/10g/server.101/b10743/process.htm|title=Oracle Database Concepts, 10g Release 1|id=B10743-01|date=December 1993|author=Michele Cyran|publisher=Oracle Corporation|accessdate=12 November 2010|archive-date=2 March 2013|archive-url=https://web.archive.org/web/20130302105539/http://www.stanford.edu/dept/itss/docs/oracle/10g/server.101/b10743/process.htm|url-status=dead}}</ref> and user notification.<ref name="ios">{{cite web|url= https://gizmodo.com/5512656/how-multitasking-works-in-the-new-iphone-os-40|title=How Multitasking Works in the New iPhone OS 4.0|date=8 April 2010|author=Jesus Diaz|accessdate=14 November 2010|publisher=Gizmodo|archiveurl= https://web.archive.org/web/20101102204211/http://gizmodo.com/5512656/how-multitasking-works-in-the-new-iphone-os-40|archivedate= 2 November 2010|url-status=live}}</ref> |
||
On a [[Microsoft Windows|Windows]] system, |
On a [[Microsoft Windows|Windows]] system, a background process is either a [[computer program]] that does not create a [[user interface]], or a [[Windows service]]. The former are started just as any other program is started, e.g., via [[Start menu]]. Windows services, on the other hand, are started by [[Service Control Manager]]. In [[Windows Vista]] and later, they [[Windows Service Hardening|are run in a separate session]].{{Citation Needed|date=April 2020}} |
||
On a [[Unix]] or [[Unix-like]] system, a background process or job can be further identified as one whose [[process group]] ID differs from its terminal group ID (TGID). (The TGID of a process is the process ID of the process group leader that opened the terminal, which is typically the login shell. The TGID identifies the control terminal of the process group.) This type of process is unable to receive keyboard signals from its parent terminal, and typically will not send output to that terminal.<ref name="bash">{{cite book|url=https://www.gnu.org/software/bash/manual/bashref.html#Job-Control|title=GNU Bash Reference Manual, Edition 4.1, Job Control Basics|date=23 December 2009|publisher=Free Software Foundation, Inc|accessdate=10 November 2010|archiveurl= https://web.archive.org/web/20101203065719/https://www.gnu.org/software/bash/manual/bashref.html|archivedate= 3 December 2010 |
On a [[Unix]] or [[Unix-like]] system, a background process or job can be further identified as one whose [[process group]] ID differs from its terminal group ID (TGID). (The TGID of a process is the process ID of the process group leader that opened the terminal, which is typically the login shell. The TGID identifies the control terminal of the process group.) This type of process is unable to receive keyboard signals from its parent terminal, and typically will not send output to that terminal.<ref name="bash">{{cite book|url=https://www.gnu.org/software/bash/manual/bashref.html#Job-Control|title=GNU Bash Reference Manual, Edition 4.1, Job Control Basics|date=23 December 2009|publisher=Free Software Foundation, Inc|accessdate=10 November 2010|archiveurl= https://web.archive.org/web/20101203065719/https://www.gnu.org/software/bash/manual/bashref.html|archivedate= 3 December 2010|url-status=live}}</ref> This more technical definition does not distinguish between whether or not the process can receive user intervention. Although background processes are typically used for purposes needing few resources, any process can be run in the background, and such a process will behave like any other process, with the exceptions given above.<ref name="tlt"/> |
||
==Windows services== |
==Windows services== |
||
Line 9: | Line 10: | ||
In [[Windows NT]] family of [[operating system]]s, a Windows service is a dedicated background process.<ref name="Services snap-in">{{cite web|title=Services overview|url=https://technet.microsoft.com/en-us/library/cc783643%28v=ws.10%29.aspx|work=[[Microsoft TechNet]]|publisher=Microsoft|accessdate=29 March 2013}}</ref> A Windows service must conform to the interface rules and protocols of the [[Service Control Manager]], the component responsible for managing Windows services.<ref name="Service MSDN">{{Cite web |url=http://msdn2.microsoft.com/en-us/library/ms685141.aspx |title=Services |work=[[Microsoft Developer Network]] |publisher=Microsoft |accessdate=29 March 2013}}</ref> |
In [[Windows NT]] family of [[operating system]]s, a Windows service is a dedicated background process.<ref name="Services snap-in">{{cite web|title=Services overview|url=https://technet.microsoft.com/en-us/library/cc783643%28v=ws.10%29.aspx|work=[[Microsoft TechNet]]|publisher=Microsoft|accessdate=29 March 2013}}</ref> A Windows service must conform to the interface rules and protocols of the [[Service Control Manager]], the component responsible for managing Windows services.<ref name="Service MSDN">{{Cite web |url=http://msdn2.microsoft.com/en-us/library/ms685141.aspx |title=Services |work=[[Microsoft Developer Network]] |publisher=Microsoft |accessdate=29 March 2013}}</ref> |
||
Windows services can be configured to start when the operating system starts, and to run in the background as long as Windows runs. |
Windows services can be configured to start when the operating system starts, and to run in the background as long as Windows runs. Alternatively, they can be started manually or by an event. Windows NT operating systems [[List of Microsoft Windows components#Services|include numerous services]] which run in context of three [[user account]]s: <code>System</code>, <code>Network Service</code> and <code>Local Service</code>. These Windows components are often associated with Host Process for Windows Services: [[svchost.exe]]. Since Windows services operate in the context of their own dedicated user accounts, they can operate when a user is not logged on. |
||
Before [[Windows Vista]] services installed as "interactive services" could interact with Windows [[desktop metaphor|desktop]] and show a [[graphical user interface]]. With Windows Vista, however, interactive services |
Before [[Windows Vista]], services installed as "interactive services" could interact with Windows [[desktop metaphor|desktop]] and show a [[graphical user interface]]. With Windows Vista, however, interactive services became [[deprecated]] and ceased operating properly, as a result of [[Windows Service Hardening]].<ref>{{cite web|title=New Elevation PowerToys for Windows Vista|url=https://technet.microsoft.com/en-us/magazine/2008.06.elevation.aspx|work=TechNet Magazine|publisher=[[Microsoft]]|accessdate=21 June 2013|date=June 2008|quote=The service CmdAsSystem is configured as interactive whose support is being deprecated. The service may not function properly. The problem is that this script tries to create and start an interactive service. Interactive services will not function correctly due to Session 0 Isolation in Windows Vista.}}</ref><ref>{{cite web|title=Services in Windows|url=http://msdn.microsoft.com/en-us/windows/hardware/gg463428.aspx|work=[[MSDN]]|publisher=[[Microsoft]]|accessdate=21 June 2013|date=18 October 2010}}</ref> |
||
The three principal means of managing Windows services are: |
The three principal means of managing Windows services are: |
||
Line 20: | Line 21: | ||
==Daemon== |
==Daemon== |
||
{{Main article|Daemon (computing)}} |
{{Main article|Daemon (computing)}} |
||
A daemon is a type of background process designed to run continually in the background, waiting for event(s) to occur or condition(s) to be met.<ref>{{cite book|url=http://catb.org/~esr/jargon/html/D/daemon.html |title=The Jargon File, version 4.4.8, "daemon" |author=Eric S. Raymond |date=1 October 2004 |accessdate=10 November 2010 |archiveurl=https://web.archive.org/web/20101103102331/http://catb.org/~esr/jargon/html/D/daemon.html |archivedate=3 November 2010 | |
A daemon is a type of background process designed to run continually in the background, waiting for event(s) to occur or condition(s) to be met.<ref>{{cite book|url=http://catb.org/~esr/jargon/html/D/daemon.html |title=The Jargon File, version 4.4.8, "daemon" |author=Eric S. Raymond |date=1 October 2004 |accessdate=10 November 2010 |archiveurl=https://web.archive.org/web/20101103102331/http://catb.org/~esr/jargon/html/D/daemon.html |archivedate=3 November 2010 |url-status=live }}</ref> When launched with the ''daemon'' function, daemons are disassociated from their parent terminal.<ref>{{cite book|url=http://libslack.org/daemon/manpages/daemon.1.html|title=Linux User's Manual, "daemon"|author=raf|date=12 June 2010|accessdate=10 November 2010|archiveurl= https://web.archive.org/web/20101021032110/http://libslack.org/daemon/manpages/daemon.1.html|archivedate= 21 October 2010|url-status=live}}</ref> |
||
== |
==Background jobs in Unix== |
||
{{main article|Job control (Unix)}} |
{{main article|Job control (Unix)}} |
||
From a Unix command line, a background process can be launched using the "&" operator. The '' |
From a Unix command line, a background process can be launched using the "&" operator. The ''bg'' command can resume a suspended job (sending [[SIGCONT]]), running it in the background. Using the ''fg'' command will also reconnect standard input its parent terminal, bringing it into the foreground. The ''jobs'' command will list all processes associated with the current terminal and can be used to bring background processes into the foreground.<ref name="bash" /><ref>{{cite web|url=http://www.astro.ku.dk/comp-phys/tutorials/background.shtml|title=Background Processes in Unix/Linux|author=Åke Nordlund|date=7 February 2007|accessdate=10 November 2010|archive-url=https://web.archive.org/web/20120213174734/http://www.astro.ku.dk/comp-phys/tutorials/background.shtml|archive-date=13 February 2012|url-status=dead}}</ref> |
||
When a [[login session]] ends, via explicit logout or network disconnection, all processes, including background processes, will by default be terminated, to prevent them from becoming [[orphan process]]es. Concretely, when the user exits the launching shell process, as part of shutdown it sends a ''hangup'' signal ([[SIGHUP]]) to all its [[Job control (Unix)|jobs]], to terminate all the processes in the corresponding [[process group]]. To have processes continue to run, one can either not end the session, or end the session without terminating the processes. A [[terminal multiplexer]] can be used to leave a session running but detach a virtual terminal from it, leaving processes running as child processes of the session; the user can then reattach session later. Or, termination can be prevented by either starting the process via the [[nohup]] command (telling the process to ignore SIGHUP), or by subsequently running [[disown (Unix)|<code>disown</code>]] with the job id, which either removes the job from the job list entirely, or simply prevents SIGHUP from being sent. In the latter case when the session ends, the child processes are not terminated, either because they are not sent SIGHUP or because they ignore it, and thus become orphan processes, which are then adopted by the [[init]] process (the kernel sets the init process as their parent), and they continue running without a session, now called ''[[Daemon (computer software)|daemons]]''. |
When a [[login session]] ends, via explicit logout or network disconnection, all processes, including background processes, will by default be terminated, to prevent them from becoming [[orphan process]]es. Concretely, when the user exits the launching shell process, as part of shutdown it sends a ''hangup'' signal ([[SIGHUP]]) to all its [[Job control (Unix)|jobs]], to terminate all the processes in the corresponding [[process group]]. To have processes continue to run, one can either not end the session, or end the session without terminating the processes. A [[terminal multiplexer]] can be used to leave a session running but detach a virtual terminal from it, leaving processes running as child processes of the session; the user can then reattach session later. Or, termination can be prevented by either starting the process via the [[nohup]] command (telling the process to ignore SIGHUP), or by subsequently running [[disown (Unix)|<code>disown</code>]] with the job id, which either removes the job from the job list entirely, or simply prevents SIGHUP from being sent. In the latter case when the session ends, the child processes are not terminated, either because they are not sent SIGHUP or because they ignore it, and thus become orphan processes, which are then adopted by the [[init]] process (the kernel sets the init process as their parent), and they continue running without a session, now called ''[[Daemon (computer software)|daemons]]''. |
||
Line 30: | Line 31: | ||
===Example=== |
===Example=== |
||
In this example running on [[Unix]], the ''sleep'' utility was launched into the background. Afterward, the ''ps'' tool was run in the foreground, where it output the below text. Both were launched from the shell.<ref>{{cite web |url=http://pubs.opengroup.org/onlinepubs/7999959899/utilities/ps.html|title=POSIX "ps"|work=IEEE Std 1003.1, 2004 Edition}}</ref> |
In this example running on [[Unix]], the ''sleep'' utility was launched into the background. Afterward, the ''ps'' tool was run in the foreground, where it output the below text. Both were launched from the shell.<ref>{{cite web |url=http://pubs.opengroup.org/onlinepubs/7999959899/utilities/ps.html|title=POSIX "ps"|work=IEEE Std 1003.1, 2004 Edition}}</ref> |
||
< |
<syntaxhighlight lang="bash"> |
||
PID TT STAT TIME COMMAND |
PID TT STAT TIME COMMAND |
||
54659 10 S 0:00.06 su (zsh) |
54659 10 S 0:00.06 su (zsh) |
||
Line 36: | Line 37: | ||
54852 10 R+ 0:00.00 - ps -U botty -axd |
54852 10 R+ 0:00.00 - ps -U botty -axd |
||
</syntaxhighlight> |
|||
</source> |
|||
==Smartphones== |
==Smartphones== |
||
Many newer versions of [[smartphone]] and PDA [[operating system]]s now include the ability to start background processes. |
Many newer versions of [[smartphone]] and PDA [[operating system]]s now include the ability to start background processes. Due to hardware limits, background processes on mobile operating systems are often restricted to certain tasks or consumption levels. On [[Android (operating system)|Android]], CPU use for background processes may be bounded at 5 - 10%.<ref name="phone">{{cite web|url=https://gizmodo.com/5527407/giz-explains-how-multitasking-works-on-a-phone|title=Giz Explains: How Multitasking Works on a Phone|author=Matt Buchanan|date=2010-04-29|publisher=Gizmodo|accessdate=14 November 2010|archiveurl= https://web.archive.org/web/20101017123040/http://gizmodo.com/5527407/giz-explains-how-multitasking-works-on-a-phone|archivedate=17 October 2010|url-status=live}}</ref> Applications on Apple's [[iOS]] are limited to a subset of functions while running in the background.<ref name="ios"/> On both iOS and Android, background processes can be killed by the system if they are using too much memory.<ref name="ios"/><ref name="phone"/> |
||
==See also== |
==See also== |
Latest revision as of 08:20, 26 November 2024
A background process is a computer process that runs behind the scenes (i.e., in the background) and without user intervention.[1] Typical tasks for these processes include logging, system monitoring, scheduling,[2] and user notification.[3]
On a Windows system, a background process is either a computer program that does not create a user interface, or a Windows service. The former are started just as any other program is started, e.g., via Start menu. Windows services, on the other hand, are started by Service Control Manager. In Windows Vista and later, they are run in a separate session.[citation needed]
On a Unix or Unix-like system, a background process or job can be further identified as one whose process group ID differs from its terminal group ID (TGID). (The TGID of a process is the process ID of the process group leader that opened the terminal, which is typically the login shell. The TGID identifies the control terminal of the process group.) This type of process is unable to receive keyboard signals from its parent terminal, and typically will not send output to that terminal.[4] This more technical definition does not distinguish between whether or not the process can receive user intervention. Although background processes are typically used for purposes needing few resources, any process can be run in the background, and such a process will behave like any other process, with the exceptions given above.[1]
Windows services
[edit]In Windows NT family of operating systems, a Windows service is a dedicated background process.[5] A Windows service must conform to the interface rules and protocols of the Service Control Manager, the component responsible for managing Windows services.[6]
Windows services can be configured to start when the operating system starts, and to run in the background as long as Windows runs. Alternatively, they can be started manually or by an event. Windows NT operating systems include numerous services which run in context of three user accounts: System
, Network Service
and Local Service
. These Windows components are often associated with Host Process for Windows Services: svchost.exe. Since Windows services operate in the context of their own dedicated user accounts, they can operate when a user is not logged on.
Before Windows Vista, services installed as "interactive services" could interact with Windows desktop and show a graphical user interface. With Windows Vista, however, interactive services became deprecated and ceased operating properly, as a result of Windows Service Hardening.[7][8]
The three principal means of managing Windows services are:
- Services snap-in for Microsoft Management Console
sc.exe
- Windows PowerShell
Daemon
[edit]A daemon is a type of background process designed to run continually in the background, waiting for event(s) to occur or condition(s) to be met.[9] When launched with the daemon function, daemons are disassociated from their parent terminal.[10]
Background jobs in Unix
[edit]From a Unix command line, a background process can be launched using the "&" operator. The bg command can resume a suspended job (sending SIGCONT), running it in the background. Using the fg command will also reconnect standard input its parent terminal, bringing it into the foreground. The jobs command will list all processes associated with the current terminal and can be used to bring background processes into the foreground.[4][11]
When a login session ends, via explicit logout or network disconnection, all processes, including background processes, will by default be terminated, to prevent them from becoming orphan processes. Concretely, when the user exits the launching shell process, as part of shutdown it sends a hangup signal (SIGHUP) to all its jobs, to terminate all the processes in the corresponding process group. To have processes continue to run, one can either not end the session, or end the session without terminating the processes. A terminal multiplexer can be used to leave a session running but detach a virtual terminal from it, leaving processes running as child processes of the session; the user can then reattach session later. Or, termination can be prevented by either starting the process via the nohup command (telling the process to ignore SIGHUP), or by subsequently running disown
with the job id, which either removes the job from the job list entirely, or simply prevents SIGHUP from being sent. In the latter case when the session ends, the child processes are not terminated, either because they are not sent SIGHUP or because they ignore it, and thus become orphan processes, which are then adopted by the init process (the kernel sets the init process as their parent), and they continue running without a session, now called daemons.
Example
[edit]In this example running on Unix, the sleep utility was launched into the background. Afterward, the ps tool was run in the foreground, where it output the below text. Both were launched from the shell.[12]
PID TT STAT TIME COMMAND
54659 10 S 0:00.06 su (zsh)
54703 10 IN 0:00.00 - sleep 1000
54852 10 R+ 0:00.00 - ps -U botty -axd
Smartphones
[edit]Many newer versions of smartphone and PDA operating systems now include the ability to start background processes. Due to hardware limits, background processes on mobile operating systems are often restricted to certain tasks or consumption levels. On Android, CPU use for background processes may be bounded at 5 - 10%.[13] Applications on Apple's iOS are limited to a subset of functions while running in the background.[3] On both iOS and Android, background processes can be killed by the system if they are using too much memory.[3][13]
See also
[edit]References
[edit]- ^ a b "What is an Operating System?, Processes". The Linux Tutorial. Archived from the original on 15 August 2020. Retrieved 14 November 2010.
- ^ Michele Cyran (December 1993). Oracle Database Concepts, 10g Release 1. Oracle Corporation. B10743-01. Archived from the original on 2 March 2013. Retrieved 12 November 2010.
- ^ a b c Jesus Diaz (8 April 2010). "How Multitasking Works in the New iPhone OS 4.0". Gizmodo. Archived from the original on 2 November 2010. Retrieved 14 November 2010.
- ^ a b GNU Bash Reference Manual, Edition 4.1, Job Control Basics. Free Software Foundation, Inc. 23 December 2009. Archived from the original on 3 December 2010. Retrieved 10 November 2010.
- ^ "Services overview". Microsoft TechNet. Microsoft. Retrieved 29 March 2013.
- ^ "Services". Microsoft Developer Network. Microsoft. Retrieved 29 March 2013.
- ^ "New Elevation PowerToys for Windows Vista". TechNet Magazine. Microsoft. June 2008. Retrieved 21 June 2013.
The service CmdAsSystem is configured as interactive whose support is being deprecated. The service may not function properly. The problem is that this script tries to create and start an interactive service. Interactive services will not function correctly due to Session 0 Isolation in Windows Vista.
- ^ "Services in Windows". MSDN. Microsoft. 18 October 2010. Retrieved 21 June 2013.
- ^ Eric S. Raymond (1 October 2004). The Jargon File, version 4.4.8, "daemon". Archived from the original on 3 November 2010. Retrieved 10 November 2010.
- ^ raf (12 June 2010). Linux User's Manual, "daemon". Archived from the original on 21 October 2010. Retrieved 10 November 2010.
- ^ Åke Nordlund (7 February 2007). "Background Processes in Unix/Linux". Archived from the original on 13 February 2012. Retrieved 10 November 2010.
- ^ "POSIX "ps"". IEEE Std 1003.1, 2004 Edition.
- ^ a b Matt Buchanan (2010-04-29). "Giz Explains: How Multitasking Works on a Phone". Gizmodo. Archived from the original on 17 October 2010. Retrieved 14 November 2010.