init

This article is about the Unix process. For the pre-Mac OS X extension mechanism, see Extension (Mac OS).

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 computer 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 using a hard-coded filename; a kernel panic will occur if the kernel is unable to start it. Init is typically assigned process identifier 1.

The design of init has diverged in Unix systems such as System III and System V, from the functionality provided by the init in Research Unix and its BSD derivatives. The usage on most Linux distributions is somewhat compatible with System V, but some distributions, such as Slackware, use a BSD-style and others, such as Gentoo, have their own customized version.

Several replacement init implementations have been created, attempting to address design limitations in the standard versions. These include launchd, the Service Management Facility, systemd and Upstart; as of March 2015, systemd has been adopted by major Linux distributions.

Research Unix-style/BSD-style

Research Unix init ran the initialization shell script located in /etc/rc,[1] then launched getty on terminals under the control of /etc/ttys.[2] 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;[3][4] in 4.3BSD, it added support for running a windowing system such as X on graphical terminals under the control of /etc/ttys.[5][6] 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.[7] The order in which scripts are executed is determined by the rcorder script based on the requirements stated in these tags.

SysV-style

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

For more details on this topic, see Runlevel.

The runlevels in System V describe certain states of a machine, characterized by the processes run. There are generally eight runlevels, three of which are "standard":

0. Halt
1. Single user mode (aka. S or s)
6. Reboot

Aside from these, every Unix and Unix-like system treats runlevels a little differently. The common denominator, the /etc/inittab file, defines what each runlevel does (if they do anything at all) in a given system.

Default runlevels

Operating system Default runlevel
AIX 2
CentOS 3 (console/server) or 5 (graphical/desktop)[8]
Debian 2[9]
Gentoo Linux 3[10]
HP-UX 3 (console/server/multiuser) or 4 (graphical)
Mac OS X 3
Mandriva Linux 3 (console/server) or 5 (graphical/desktop)
Red Hat Enterprise Linux / Fedora 3 (console/server) or 5 (graphical/desktop)[8]
Slackware Linux 3
Solaris 3[11]
SUSE Linux Enterprise/openSUSE Linux 3 (console/server) or 5 (graphical/desktop)[12]
Ubuntu (Server and Desktop) 2[9]
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 operating system typically reserves 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.[13] The root 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.

Replacements for init

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.

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

References

  1. init(8)  Version 7 Unix Programmer's Manual
  2. ttys(5)  Version 7 Unix Programmer's Manual
  3. init(8)  4.2BSD System Manager's Manual
  4. ttys(5)  4.2BSD File Formats Manual
  5. init(8)  4.3BSD System Manager's Manual
  6. ttys(5)  4.3BSD File Formats Manual
  7. Andrew Smallshaw (7 December 2009). "Unix and Linux startup scripts, Part 2".
  8. 8.0 8.1 "SysV Init Runlevels". Retrieved 22 September 2012.
  9. 9.0 9.1 "Debian and Ubuntu Linux Run Levels". Debianadmin.com. 2009-04-02. Retrieved 2011-06-13.
  10. "Initscripts". Gentoo Linux Documentation. Gentoo.org. 2011-03-02. Retrieved 2011-06-13.
  11. "Oracle Documentation". Docs.sun.com. 2010-09-07. Retrieved 2011-06-13.
  12. "SUSE Documentation: The init Process". suse.com. 2014-04-25. Retrieved 2014-05-04.
  13. "UNIX man pages : runlevel (8)". Unixhelp.ed.ac.uk. 1997-05-27. Retrieved 2014-07-12.
  14. "eINIT git repository XML module directory".
  15. "Epoch Init System Homepage".
  16. Gürer Özen, Görkem Çetin. "Speeding Up Linux: One Step Further With Pardus Pardus". Pardus.org.tr. Retrieved 2011-06-13.
  17. "s6 - skarnet's small supervision suite".

External links