Misplaced Pages

Init: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 19:48, 26 May 2015 edit203.161.15.18 (talk) Strong debates towards init replacements are ongoing. It is more accurate to reflect the current state of affairs.← Previous edit Latest revision as of 06:19, 3 January 2025 edit undoPekidi9995 (talk | contribs)7 edits Other implementations: Added additional information about distrosTags: Mobile edit Mobile web edit Advanced mobile edit 
(199 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
{{Short description|UNIX system component}}
{{About|the Unix process||INIT (disambiguation)}} {{About|the Unix process||INIT (disambiguation)}}
{{Primary sources|date=December 2020}}
{{Lowercase title}} {{Lowercase title}}
]: <tt>/etc</tt> listing, showing <tt>init</tt> and <tt>rc</tt>]] ]: {{mono|/etc}} listing, showing {{mono|init}} and {{mono|rc}}]]
] script]] ] script]]


In ]-based computer ]s, '''init''' (short for ''initialization'') is the first ] started during ] of the computer system. Init is a ] process that continues running until the system is shut down. It is the direct or indirect ] of all other processes and automatically adopts all ]. Init is started by the ] using a ] ]; a ] will occur if the kernel is unable to start it. Init is typically assigned ] 1. In ]-based computer ]s, '''init''' (short for ''initialization'') is the first ] started during ] of the operating system. Init is a ] process that continues running until the system is shut down. It is the direct or indirect ] of all other processes and automatically adopts all ]. Init is started by the ] during the ] process; a ] will occur if the kernel is unable to start it, or it should die for any reason. Init is typically assigned ] 1.


In Unix systems such as ] and ], the design of init has diverged from the functionality provided by the init in ] and its ] derivatives. The usage in most ]s employing a traditional init rather than a recent variant such as ] is somewhat compatible with System&nbsp;V, while some distributions such as ] use BSD-style startup scripts, and others such as ] have their own customized versions. In Unix systems such as ] and ], the design of init has diverged from the functionality provided by the init in ] and its ] derivatives. Up until the early 2010s,<ref>{{Cite web |date=2018-11-08 |title=Lennart Poettering on systemd's Tumultuous Ascendancy |website=The New Stack |url=https://thenewstack.io/unix-greatest-inspiration-behind-systemd/ |access-date=2024-01-30 |archive-url=https://web.archive.org/web/20181108025744/https://thenewstack.io/unix-greatest-inspiration-behind-systemd/ |archive-date=2018-11-08 |url-status=live}}</ref>{{failed verification|date=February 2024}} most ]s employed a traditional init that was somewhat compatible with System&nbsp;V, while some distributions such as ] use BSD-style startup scripts, and other distributions such as ] have their own customized versions.


Several replacement init implementations have been created, attempting to address design limitations in the standard versions. These include ], the ], ] and ]; {{As of|2015|3|lc=yes}}, systemd has been ] by major Linux distributions although it remains ]. Since then, several additional init implementations have been created, attempting to address design limitations in the traditional versions. These include ], the ], ], ] and ].


== {{Anchor|STARTUP-SCRIPTS}}Research Unix-style/BSD-style == == {{Anchor|STARTUP-SCRIPTS}}Research Unix-style/BSD-style ==
] init ran the initialization ] located in <code>/etc/rc</code>,<ref>{{man|8|init|v7}}</ref> then launched ] on terminals under the control of <code>/etc/ttys</code>.<ref>{{man|5|ttys|v7}}</ref> There are no runlevels; the <code>/etc/rc</code> file determines what programs are run by init. The advantage of this system is that it is simple and easy to edit manually. However, new software added to the system may require changes to existing files that risk producing an unbootable system. ] init runs the initialization ] located at <code>/etc/rc</code>,<ref>{{man|8|init|v7}}</ref> then launches ] on terminals under the control of <code>/etc/ttys</code>.<ref>{{man|5|ttys|v7}}</ref> There are no runlevels; the <code>/etc/rc</code> file determines what programs are run by init. The advantage of this system is that it is simple and easy to edit manually. However, new software added to the system may require changes to existing files that risk producing an unbootable system.


] init was, prior to 4.3BSD, the same as Research UNIX's init;<ref>{{man|8|init|4.2BSD}}</ref><ref>{{man|5|ttys|4.2BSD}}</ref> in ], it added support for running a ] such as ] on graphical terminals under the control of <code>/etc/ttys</code>.<ref>{{man|8|init|4.3BSD}}</ref><ref>{{man|5|ttys|4.3BSD}}</ref> To remove the requirement to edit <code>/etc/rc</code>, BSD variants have long supported a site-specific <code>/etc/rc.local</code> file that is run in a sub-shell near the end of the boot sequence. ] init was, prior to 4.3BSD, the same as Research UNIX's init;<ref>{{man|8|init|4.2BSD}}</ref><ref>{{man|5|ttys|4.2BSD}}</ref> in ], it added support for running a ] such as ] on graphical terminals under the control of <code>/etc/ttys</code>.<ref>{{man|8|init|4.3BSD}}</ref><ref>{{man|5|ttys|4.3BSD}}</ref> To remove the requirement to edit <code>/etc/rc</code>, BSD variants have long supported a site-specific <code>/etc/rc.local</code> file that is run in a sub-shell near the end of the boot sequence.


A fully modular system was introduced with ] 1.5 and ported to ] 5.0 and successors. This system executes scripts in the <code>/etc/rc.d</code> directory. Unlike System V's script ordering, which is derived from the filename of each script, this system uses explicit dependency tags placed within each script.<ref>{{cite web | url = http://aplawrence.com/Basics/unix-startup-scripts-2.html | title = Unix and Linux startup scripts, Part 2 | author = Andrew Smallshaw | date = 7 December 2009 }}</ref> The order in which scripts are executed is determined by the ''rcorder'' script based on the requirements stated in these tags. A fully modular system was introduced with ] 1.5 and ported to ] 5.0 and successors. This system executes scripts in the <code>/etc/rc.d</code> directory. Unlike System V's script ordering, which is derived from the filename of each script, this system uses explicit dependency tags placed within each script.<ref>{{cite web | url = http://aplawrence.com/Basics/unix-startup-scripts-2.html | title = Unix and Linux startup scripts, Part 2 | author = Andrew Smallshaw | date = 7 December 2009 | access-date = 6 June 2011 | archive-date = 18 December 2009 | archive-url = https://web.archive.org/web/20091218083059/http://aplawrence.com/Basics/unix-startup-scripts-2.html | url-status = live }}</ref> The order in which scripts are executed is determined by the ''rcorder'' utility based on the requirements stated in these tags.


== {{Anchor|SYSV}}SysV-style == == {{Anchor|SYSV}}SysV-style ==
] utility that selects which SysV-style init scripts will be run in each runlevel]]
When compared to its predecessors, AT&T's ] introduced a new style of system startup configuration,{{Citation needed|date=October 2014}} which survived (with modifications) into ] and is therefore called the "SysV-style init". At any moment, a running System V is in one of the predetermined number of states, called '']s''. At least one runlevel is the normal operating state of the system; typically, other runlevels represent single-user mode (used for repairing a faulty system), system shutdown, and various other states. Switching from one runlevel to another causes a per-runlevel set of scripts to be run, which typically mount filesystems, start or stop ], start or stop the ], shutdown the machine, etc.


When compared to its predecessors, AT&T's ] introduced a new style of system startup configuration,<ref>{{cite web|url=http://minnie.tuhs.org/cgi-bin/utree.pl?file=SysIII%2Fusr%2Fsrc%2Fman%2Fman8%2Finit.8|title=init(8)|work=minnie.tuhs.org|access-date=2015-09-12|archive-date=2021-07-27|archive-url=https://web.archive.org/web/20210727193510/https://minnie.tuhs.org/cgi-bin/utree.pl?file=SysIII%2Fusr%2Fsrc%2Fman%2Fman8%2Finit.8|url-status=live}}</ref> which survived (with modifications) into ] and is therefore called the "SysV-style init".
=== Runlevels ===
{{Details|Runlevel}}


At any moment, a running System V is in one of the predetermined number of states, called '']s''. At least one runlevel is the normal operating state of the system; typically, other runlevels represent single-user mode (used for repairing a faulty system), system shutdown, and various other states. Switching from one runlevel to another causes a per-runlevel set of scripts to be run, which typically mount filesystems, start or stop ], start or stop the ], shutdown the machine, etc.
The ]s in System&nbsp;V describe certain states of a machine, characterized by the processes and daemons running in each of them. In general, there are eight runlevels, out of which three runlevels are considered "standard" as they are essential to the operation of a system:


=== Runlevels ===
: 0. Halt
{{Details|Runlevel}}
: 1. ] (also known as ''S'' or ''s'')
: 6. ]


The ]s in System&nbsp;V describe certain states of a machine, characterized by the processes and daemons running in each of them. In general, there are seven runlevels, out of which three runlevels are considered "standard", as they are essential to the operation of a system:
{{ordered list
|item1_value=0 | ]
|item2_value=1 | ] (also known as ''S'' or ''s'')
|item3_value=6 | ]
}}
Aside from these standard ones, Unix and Unix-like systems treat runlevels somewhat differently. The common denominator, the <code>/etc/inittab</code> file, defines what each configured runlevel does in a given system. Aside from these standard ones, Unix and Unix-like systems treat runlevels somewhat differently. The common denominator, the <code>/etc/inittab</code> file, defines what each configured runlevel does in a given system.


=== Default runlevels === === Default runlevels ===
{| class="wikitable floatright" style="margin-left: 1.5em;" {| class="wikitable floatright sortable" style="margin-left: 1.5em;"
|- |-
! Operating system ! Operating system
Line 40: Line 46:
| 2 | 2
|- |-

| ] | ]
| 3 (console/server) or 5 (graphical/desktop)<ref name=runlevel>{{cite web |title=SysV Init Runlevels |url=http://www.centos.org/docs/5/html/Installation_Guide-en-US/s1-boot-init-shutdown-sysv.html |accessdate=22 September 2012}}</ref>
|- | 5
| ]
| 2<ref name="drl">{{cite web |url=http://www.debianadmin.com/debian-and-ubuntu-linux-run-levels.html |title=Debian and Ubuntu Linux Run Levels |publisher=Debianadmin.com |date=2009-04-02 |accessdate=2011-06-13}}</ref>
|- |-
| ] | ]
| 3<ref>{{cite web |url=http://www.gentoo.org/doc/en/handbook/handbook-x86.xml?part=2&chap=4 |title=Initscripts |work = Gentoo Linux Documentation |publisher=Gentoo.org |date=2011-03-02 |accessdate=2011-06-13}}</ref> | 3<ref>{{cite web |url=https://wiki.gentoo.org/wiki/Handbook:X86/Working/Initscripts |title=Initscripts |work=Gentoo Linux Documentation |publisher=Gentoo.org |date=2014-12-13 |access-date=2020-12-08 |archive-date=2020-12-03 |archive-url=https://web.archive.org/web/20201203013811/https://wiki.gentoo.org/Handbook:X86/Working/Initscripts |url-status=live }}</ref>
|- |-
| ] | ]
| 3 (console/server/multiuser) or 4 (graphical) | 3 (console/server/multiuser) or 4 (graphical)

|- |-

| ]
| ]

| 3 | 3

|- |-

| ]
| 3 (console/server) or 5 (graphical/desktop)
|-
| ] / ]
| 3 (console/server) or 5 (graphical/desktop)<ref name=runlevel />
|- |-
| ] | ]
| 3 | 3
|- |-
| ] | ] / ]
| 3<ref>{{cite web |url=https://docs.oracle.com/cd/E23824_01/html/821-1451/hbrunlevels-13026.html |title=Run Levels |publisher=] |work=Oracle Solaris Administration: Common Tasks |access-date=2017-11-14 |archive-date=2016-04-10 |archive-url=https://web.archive.org/web/20160410084238/http://docs.oracle.com/cd/E23824_01/html/821-1451/hbrunlevels-13026.html |url-status=live }}</ref>
| 3<ref>{{cite web |url=http://docs.sun.com/app/docs/doc/817-1985/6mhm8o5ru |title=Oracle Documentation |publisher=Docs.sun.com |date=2010-09-07 |accessdate=2011-06-13}}</ref>
|-
| ]
| 3 (console/server) or 5 (graphical/desktop)<ref>{{cite web |url=https://www.suse.com/documentation/sles11/book_sle_admin/data/sec_boot_init.html |title=SUSE Documentation: The init Process |publisher=suse.com |date=2014-04-25 |accessdate=2014-05-04}}</ref>
|-
| ]
| 2<ref name="drl" />
|- |-
| ] Releases 3.x, 4.x | ] Releases 3.x, 4.x
Line 80: Line 78:
|} |}


On Linux distributions defaulting to runlevel 5 in the table on the right, runlevel 5 invokes a multiuser graphical environment running the ], usually with a ] like ] or ]. However, the ] operating system typically reserves runlevel 5 to shut down and automatically power off the machine. On Linux distributions defaulting to runlevel 5 in the table on the right, runlevel 5 invokes a multiuser graphical environment running the ], usually with a ] like ] or ]. However, the ] and ] operating systems typically reserve runlevel 5 to shut down and automatically power off the machine.


On most systems, all users can check the current runlevel with either the <code>runlevel</code> or <code>] -r</code> command.<ref>{{cite web |url=http://unixhelp.ed.ac.uk/CGI/man-cgi?runlevel+8 |title=UNIX man pages : runlevel (8) |publisher=Unixhelp.ed.ac.uk |date=1997-05-27 |accessdate=2014-07-12}}</ref> The ] typically changes the current runlevel by running the <code>telinit</code> or <code>init</code> commands. The <code>/etc/inittab</code> file sets the default runlevel with the <code>:initdefault:</code> entry. On most systems, all users can check the current runlevel with either the <code>runlevel</code> or <code>] -r</code> command.<ref>{{cite web |url=http://unixhelp.ed.ac.uk/CGI/man-cgi?runlevel+8 |title=UNIX man pages : runlevel (8) |publisher=Unixhelp.ed.ac.uk |date=1997-05-27 |access-date=2014-07-12 |archive-url=https://web.archive.org/web/20140714112953/http://unixhelp.ed.ac.uk/CGI/man-cgi?runlevel+8 |archive-date=2014-07-14 |url-status=dead }}</ref> The ] user typically changes the current runlevel by running the <code>telinit</code> or <code>init</code> commands. The <code>/etc/inittab</code> file sets the default runlevel with the <code>:initdefault:</code> entry.


On Unix systems, changing the runlevel is achieved by starting only the missing services (as each level defines only those that are started / stopped).{{Citation needed|date=May 2013}} For example, changing a system from runlevel 3 to 4 might only start the local X server. Going back to runlevel 3, it would be stopped again. On Unix systems, changing the runlevel is achieved by starting only the missing services (as each level defines only those that are started / stopped).{{Citation needed|date=May 2013}} For example, changing a system from runlevel 3 to 4 might only start the local X server. Going back to runlevel 3, it would be stopped again.


== {{Anchor|S6}}Replacements for init == == {{Anchor|S6}}Other implementations ==
Traditionally, one of the major drawbacks of init is that it starts tasks serially, waiting for each to finish loading before moving on to the next. When startup processes end up I/O blocked, this can result in long delays during boot. Traditionally, one of the major drawbacks of init is that it starts tasks serially, waiting for each to finish loading before moving on to the next. When startup processes end up ] (I/O) blocked, this can result in long delays during boot. Speeding up I/O, e.g. by using SSDs, may shorten the delays but it does not address the root cause.


Various efforts have been made to replace the traditional init daemons to address this and other design problems, including: Various efforts have been made to replace the traditional init daemons to address this and other design problems, including:
* ] in ] * ] in ]
* ], suited ]s, employed by ] before it was replaced with ] * ], suited to ]s, used by ] (before being replaced with ]), ] 5 (Rolling), ], and ], and used by ] before it was replaced with ]
* Dinit, a service manager and init system.<ref>{{cite web |url=https://github.com/davmac314/dinit |title=GitHub - davmac314/dinit: Service monitoring / "init" system |website=] |access-date=2021-12-12 |archive-date=2021-12-12 |archive-url=https://web.archive.org/web/20211212163253/https://github.com/davmac314/dinit |url-status=live }}</ref>
* ], a modification of the init start process by ], where daemons are started only when the DE (desktop environment) started{{cn|date=July 2014}}
* ], a single-threaded Linux init system focused on simplicity and service management<ref>{{cite web |url=http://universe2.us/epoch.html |title=Epoch Init System Homepage |access-date=2014-07-31 |archive-date=2014-08-02 |archive-url=https://web.archive.org/web/20140802142947/http://universe2.us/epoch.html |url-status=live }}</ref>
* eINIT, a full replacement of init designed to start processes ]ly, but with the potential of doing it without ].<ref>{{cite web|url=https://github.com/eINIT/xml-sh/tree/master/data/modules-xml | title=eINIT git repository XML module directory}}</ref>
* ], a single-threaded Linux init system focused on simplicity and service management<ref>{{cite web|url=http://universe2.us/epoch.html | title=Epoch Init System Homepage}}</ref> * ], a software package that consists of an init system and a service management system<ref>{{Cite web |last=Wood-Mattheusson |first=S. M. |date=2024-12-16 |title=ginitd: det effektivaste init-systemet |url=https://ylur.me/gershwin/ginitd }}</ref>
* ], a full replacement of init designed to start processes ]ly * ], a full replacement of init designed to start processes asynchronously
* ], a replacement for init introduced in ] (it launches SystemStarter to run old-style <nowiki>'rc.local'</nowiki> and SystemStarter processes) * ], a replacement for init in ]/]/]/] starting with ] (it launches SystemStarter to run old-style <nowiki>'rc.local'</nowiki> and SystemStarter processes)
* ], a process spawner that utilizes system-provided init, while providing process isolation, parallelized startup, and service dependency; used by ], ] and its derivatives, and available as an option in ] and ].
* Mudur, an init replacement written in ] and designed to start process ]ly in use by the ] Linux distribution.<ref>{{cite web|url=http://www.pardus.org.tr/eng/projects/comar/SpeedingUpLinuxWithPardus.html |title=Speeding Up Linux: One Step Further With Pardus Pardus | author = Gürer Özen, Görkem Çetin |publisher=Pardus.org.tr |date= |accessdate=2011-06-13}}</ref>
* ], a cross-platform full replacement for init with parallel starting of services, used by default in ]<ref>{{Cite web |url=http://voidlinux.org/ |title=Void Linux main page |access-date=2020-08-31 |archive-date=2020-08-29 |archive-url=https://web.archive.org/web/20200829154800/https://voidlinux.org/ |url-status=live }}</ref>
* ], a process spawner that utilizes system-provided init, while providing process isolation, parallelized startup, and service dependency. Used by ] and its derivatives.
* Sun ] (SMF), a complete replacement/redesign of init from the ground up in ]/] starting with Solaris 10, but launched as the only service by the original System&nbsp;V-style init
* ], a ] full replacement for init with parallel starting of services
* ], the ] service and daemon manager which provides asynchronous, dependency-based initialisation; written in ] and meant to be interactively hackable during normal system operation<ref>{{cite web |url=https://www.gnu.org/software/shepherd/ |title=The Shepherd - GNU Project |publisher=Free Software Foundation, Inc. |access-date=2016-01-16 |archive-date=2016-02-12 |archive-url=https://web.archive.org/web/20160212224150/https://www.gnu.org/software/shepherd/ |url-status=live }}</ref>
* s6, another ] full replacement for init, similar to runit<ref>{{cite web|url=http://skarnet.org/software/s6/ | title=s6 - skarnet's small supervision suite}}</ref>
* ], a software suite that includes an init system. <ref>{{cite web |url=https://www.skarnet.org/software/s6/why.html |title=s6: why another supervision suite |access-date=2021-09-13 |archive-date=2021-09-13 |archive-url=https://web.archive.org/web/20210913201711/https://skarnet.org/software/s6/why.html |url-status=live }}</ref><ref>{{cite web |url=https://www.linuxquestions.org/questions/slackware-14/s6-init-system-4175658553/ |url-status=dead |archive-url=https://web.archive.org/web/20210913201707/https://www.linuxquestions.org/questions/slackware-14/s6-init-system-4175658553/ |archive-date=2021-09-13 |title=s6 init system}}</ref>
* ], a complete replacement/redesign of init from the ground up in ] starting with Solaris 10, but launched as the only service by the original System&nbsp;V-style init.
* ], a full replacement for init in Linux with concurrent starting of services and other features, used by ]. * ], a software suite, full replacement for init in Linux that includes an init daemon, with concurrent starting of services, service manager, and other features. Used by ] (replaces SysV init), ] among other popular linux distributions.
* ], a process spawner started by the BSD-style init in ] prior to ] * ], a process spawner started by the BSD-style init in ] prior to Mac&nbsp;OS&nbsp;X v10.4
* ], a full replacement of init designed to start processes asynchronously. Initiated by ] and used by them until 2014. It was also used in Fedora 9,<ref>{{citation |url=https://fedoraproject.org/Releases/14/FeatureList |title=Fedora 14 Accepted Features |date=2010-07-13 |access-date=2010-07-13 |archive-date=2022-03-27 |archive-url=https://web.archive.org/web/20220327191742/https://fedoraproject.org/Releases/14/FeatureList |url-status=live }}</ref><ref>{{cite web |url=https://lwn.net/Articles/405100/ |title=Fedora defers systemd to F15 |date=2010-09-14 |access-date=2010-09-17 |publisher=Linux Weekly News |archive-date=2010-09-19 |archive-url=https://web.archive.org/web/20100919142259/http://lwn.net/Articles/405100/ |url-status=live }}</ref> Red Hat Enterprise Linux 6<ref>{{cite web |url=https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/6/html/6.0_technical_notes/deployment |publisher=] |title=Deployment |work=Red Hat Enterprise Linux 6: Technical Notes |access-date=2013-12-31 |archive-date=2018-08-29 |archive-url=https://web.archive.org/web/20180829175441/https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/6/html/6.0_technical_notes/deployment |url-status=live }}</ref> and ]'s ].<ref name="chrome-os">{{citation |url=https://sites.google.com/a/chromium.org/dev/chromium-os/chromiumos-design-docs/software-architecture |title=Software Architecture: Chromium OS design documents |access-date=25 January 2014 |archive-date=9 April 2022 |archive-url=https://web.archive.org/web/20220409203000/https://sites.google.com/a/chromium.org/dev/chromium-os/chromiumos-design-docs/software-architecture |url-status=live }}</ref>
* ], a full replacement of init designed to start processes ]ly initiated by ].

{{As of|2019|2}}, systemd has been ] by most major Linux distributions.<ref>See ]</ref>


== See also == == See also ==
{{Portal|Computing}}
* ] * ]
* ] — an equivalent in Windows NT


== References == == References ==
Line 114: Line 114:


== External links == == External links ==
* *
* * (2007)
* * {{webarchive |url=https://web.archive.org/web/20051231110711/http://www.sun.com/bigadmin/content/selfheal/smf-quickstart.html |date=December 31, 2005 |title=Solaris Service Management Facility - Quickstart Guide }}
* {{Webarchive|url=https://web.archive.org/web/20151011235646/http://blog.darknedgy.net/technology/2015/09/05/0/ |date=2015-10-11 }}


{{Service management in Unix}} {{Service management in Unix}}


] ]

Latest revision as of 06:19, 3 January 2025

UNIX system component This article is about the Unix process. For other uses, see INIT (disambiguation).
This article relies excessively on references to primary sources. Please improve this article by adding secondary or tertiary sources.
Find sources: "Init" – news · newspapers · books · scholar · JSTOR (December 2020) (Learn how and when to remove this message)
Version 7 Unix: /etc listing, showing init and rc
Version 7 Unix: contents of an /etc/rc Bourne shell script

In Unix-based computer operating systems, init (short for initialization) is the first process started during booting of the operating system. Init is a daemon process that continues running until the system is shut down. It is the direct or indirect ancestor of all other processes and automatically adopts all orphaned processes. Init is started by the kernel during the booting process; a kernel panic will occur if the kernel is unable to start it, or it should die for any reason. Init is typically assigned process identifier 1.

In Unix systems such as System III and System V, the design of init has diverged from the functionality provided by the init in Research Unix and its BSD derivatives. Up until the early 2010s, most Linux distributions employed a traditional init that was somewhat compatible with System V, while some distributions such as Slackware use BSD-style startup scripts, and other distributions such as Gentoo have their own customized versions.

Since then, several additional init implementations have been created, attempting to address design limitations in the traditional versions. These include launchd, the Service Management Facility, systemd, Runit and OpenRC.

Research Unix-style/BSD-style

Research Unix init runs the initialization shell script located at /etc/rc, then launches getty on terminals under the control of /etc/ttys. There are no runlevels; the /etc/rc file determines what programs are run by init. The advantage of this system is that it is simple and easy to edit manually. However, new software added to the system may require changes to existing files that risk producing an unbootable system.

BSD init was, prior to 4.3BSD, the same as Research UNIX's init; in 4.3BSD, it added support for running a windowing system such as X on graphical terminals under the control of /etc/ttys. To remove the requirement to edit /etc/rc, BSD variants have long supported a site-specific /etc/rc.local file that is run in a sub-shell near the end of the boot sequence.

A fully modular system was introduced with NetBSD 1.5 and ported to FreeBSD 5.0 and successors. This system executes scripts in the /etc/rc.d directory. Unlike System V's script ordering, which is derived from the filename of each script, this system uses explicit dependency tags placed within each script. The order in which scripts are executed is determined by the rcorder utility based on the requirements stated in these tags.

SysV-style

sysv-rc-conf, a TUI utility that selects which SysV-style init scripts will be run in each runlevel

When compared to its predecessors, AT&T's UNIX System III introduced a new style of system startup configuration, which survived (with modifications) into UNIX System V and is therefore called the "SysV-style init".

At any moment, a running System V is in one of the predetermined number of states, called runlevels. At least one runlevel is the normal operating state of the system; typically, other runlevels represent single-user mode (used for repairing a faulty system), system shutdown, and various other states. Switching from one runlevel to another causes a per-runlevel set of scripts to be run, which typically mount filesystems, start or stop daemons, start or stop the X Window System, shutdown the machine, etc.

Runlevels

Further information: Runlevel

The runlevels in System V describe certain states of a machine, characterized by the processes and daemons running in each of them. In general, there are seven runlevels, out of which three runlevels are considered "standard", as they are essential to the operation of a system:

  1. Turn off
  2. Single-user mode (also known as S or s)
  3. Reboot

Aside from these standard ones, Unix and Unix-like systems treat runlevels somewhat differently. The common denominator, the /etc/inittab file, defines what each configured runlevel does in a given system.

Default runlevels

Operating system Default runlevel
AIX 2
antiX 5
Gentoo Linux 3
HP-UX 3 (console/server/multiuser) or 4 (graphical)
Linux From Scratch 3
Slackware Linux 3
Solaris / illumos 3
UNIX System V Releases 3.x, 4.x 2
UnixWare 7.x 3

On Linux distributions defaulting to runlevel 5 in the table on the right, runlevel 5 invokes a multiuser graphical environment running the X Window System, usually with a display manager like GDM or KDM. However, the Solaris and illumos operating systems typically reserve runlevel 5 to shut down and automatically power off the machine.

On most systems, all users can check the current runlevel with either the runlevel or who -r command. The root user typically changes the current runlevel by running the telinit or init commands. The /etc/inittab file sets the default runlevel with the :initdefault: entry.

On Unix systems, changing the runlevel is achieved by starting only the missing services (as each level defines only those that are started / stopped). For example, changing a system from runlevel 3 to 4 might only start the local X server. Going back to runlevel 3, it would be stopped again.

Other implementations

Traditionally, one of the major drawbacks of init is that it starts tasks serially, waiting for each to finish loading before moving on to the next. When startup processes end up Input/output (I/O) blocked, this can result in long delays during boot. Speeding up I/O, e.g. by using SSDs, may shorten the delays but it does not address the root cause.

Various efforts have been made to replace the traditional init daemons to address this and other design problems, including:

  • BootScripts in GoboLinux
  • busybox-init, suited to embedded operating systems, used by Alpine Linux (before being replaced with OpenRC), SliTaz 5 (Rolling), Tiny Core Linux, and VMware ESXi, and used by OpenWrt before it was replaced with procd
  • Dinit, a service manager and init system.
  • Epoch, a single-threaded Linux init system focused on simplicity and service management
  • ginitd, a software package that consists of an init system and a service management system
  • Initng, a full replacement of init designed to start processes asynchronously
  • launchd, a replacement for init in Darwin/macOS/iOS/tvOS starting with Mac OS X v10.4 (it launches SystemStarter to run old-style 'rc.local' and SystemStarter processes)
  • OpenRC, a process spawner that utilizes system-provided init, while providing process isolation, parallelized startup, and service dependency; used by Alpine Linux, Gentoo and its derivatives, and available as an option in Devuan and Artix Linux.
  • runit, a cross-platform full replacement for init with parallel starting of services, used by default in Void Linux
  • Sun Service Management Facility (SMF), a complete replacement/redesign of init from the ground up in illumos/Solaris starting with Solaris 10, but launched as the only service by the original System V-style init
  • Shepherd, the GNU service and daemon manager which provides asynchronous, dependency-based initialisation; written in Guile Scheme and meant to be interactively hackable during normal system operation
  • s6, a software suite that includes an init system.
  • systemd, a software suite, full replacement for init in Linux that includes an init daemon, with concurrent starting of services, service manager, and other features. Used by Debian (replaces SysV init), Ubuntu among other popular linux distributions.
  • SystemStarter, a process spawner started by the BSD-style init in Mac OS X prior to Mac OS X v10.4
  • Upstart, a full replacement of init designed to start processes asynchronously. Initiated by Ubuntu and used by them until 2014. It was also used in Fedora 9, Red Hat Enterprise Linux 6 and Google's ChromeOS.

As of February 2019, systemd has been adopted by most major Linux distributions.

See also

References

  1. "Lennart Poettering on systemd's Tumultuous Ascendancy". The New Stack. 2018-11-08. Archived from the original on 2018-11-08. Retrieved 2024-01-30.
  2. init(8) – Version 7 Unix Programmer's Manual
  3. ttys(5) – Version 7 Unix Programmer's Manual
  4. init(8) – 4.2BSD System Manager's Manual
  5. ttys(5) – 4.2BSD File Formats Manual
  6. init(8) – 4.3BSD System Manager's Manual
  7. ttys(5) – 4.3BSD File Formats Manual
  8. Andrew Smallshaw (7 December 2009). "Unix and Linux startup scripts, Part 2". Archived from the original on 18 December 2009. Retrieved 6 June 2011.
  9. "init(8)". minnie.tuhs.org. Archived from the original on 2021-07-27. Retrieved 2015-09-12.
  10. "Initscripts". Gentoo Linux Documentation. Gentoo.org. 2014-12-13. Archived from the original on 2020-12-03. Retrieved 2020-12-08.
  11. "Run Levels". Oracle Solaris Administration: Common Tasks. Oracle. Archived from the original on 2016-04-10. Retrieved 2017-11-14.
  12. "UNIX man pages : runlevel (8)". Unixhelp.ed.ac.uk. 1997-05-27. Archived from the original on 2014-07-14. Retrieved 2014-07-12.
  13. "GitHub - davmac314/dinit: Service monitoring / "init" system". GitHub. Archived from the original on 2021-12-12. Retrieved 2021-12-12.
  14. "Epoch Init System Homepage". Archived from the original on 2014-08-02. Retrieved 2014-07-31.
  15. Wood-Mattheusson, S. M. (2024-12-16). "ginitd: det effektivaste init-systemet".
  16. "Void Linux main page". Archived from the original on 2020-08-29. Retrieved 2020-08-31.
  17. "The Shepherd - GNU Project". Free Software Foundation, Inc. Archived from the original on 2016-02-12. Retrieved 2016-01-16.
  18. "s6: why another supervision suite". Archived from the original on 2021-09-13. Retrieved 2021-09-13.
  19. "s6 init system". Archived from the original on 2021-09-13.
  20. Fedora 14 Accepted Features, 2010-07-13, archived from the original on 2022-03-27, retrieved 2010-07-13
  21. "Fedora defers systemd to F15". Linux Weekly News. 2010-09-14. Archived from the original on 2010-09-19. Retrieved 2010-09-17.
  22. "Deployment". Red Hat Enterprise Linux 6: Technical Notes. Red Hat. Archived from the original on 2018-08-29. Retrieved 2013-12-31.
  23. Software Architecture: Chromium OS design documents, archived from the original on 9 April 2022, retrieved 25 January 2014
  24. See Systemd#Adoption

External links

Service management in Unix-like systems
Portable implementations
Operating-system-specific
Process supervision tools
Category: