When a Linux system is booted it passes through several distinct stages, known as runlevels, before the system has completed booting and is usable. Likewise, when a Linux system is shut down it passes through another set of runlevels before the system is ready to be turned off. In this column, we are going to examine runlevels and show you some tricks that can be used to avoid unnecessary reboots of your Linux system.
A runlevel could be referred to as a system state. They can also be considered as similar to the several modes into which Microsoft Windows is able to boot: Normal, Safe-mode and Command prompt only. Each runlevel has a collection of associated services that are initialised or stopped when the system enters the runlevel. These services are represented by initialisation scripts located in the directory corresponding to each runlevel: /etc/rc.d/rc?.d or /etc/rc?.d, where ? is the number corresponding to the runlevel.
There are generally eight runlevels used by most Linux distributions, though some may vary this organisation slightly.
|| Halt the system
|| Single user mode
|| Basic multi user mode
|| Multi user mode
|| Multi user mode with GUI
|| Reboot the system
| S, s
|| Single user mode
Most desktop Linux systems by default boot into runlevel 5 and greet the user with a graphical login prompt. Most server systems by default boot into runlevel 3 and greet the user with a text-mode login prompt. Runlevels 1and 2 are rarely used outside of debugging purposes. Runlevels S and s are not intended for direct use by users and are used to prepare the system for Single User mode.
The advantage Linux runlevels have over Windows’ boot modes is that Linux runlevels can be changed on the fly using the ‘init’ tool. You already unknowingly change runlevels on the fly whenever you shut down or reboot your Linux system. Part of the shutdown process involves calling init with the corresponding runlevel (0 or 6) to stop all running processes.
Displaying the runlevel
To begin, you may be curious to know which runlevel your system was previously and is currently in. The ‘runlevel’ command can be used to find out this information:
The output of the runlevel command tells me my system was previously in runlevel 3 and is currently in runlevel 5.
To switch runlevels use the ‘telinit’ command to control the ‘init’ process (as root):
A common reason to switch runlevels is to restart certain applications such as XFree86. Switching from runlevel 5 to runlevel 3 will stop XFree86 and its associated programs. XFree86 can then be restarted cleanly by switching back to runlevel 5. Before trying this, be sure to save any work underway in XFree86, as all GUI applications will be stopped. To try restarting XFree86 using init, type (as root):
$ /sbin/telinit 3
$ /sbin/telinit 5
After typing each command your screen will likely fill with messages as each service is started or stopped.
Adding services to a runlevel
To add a service to be started at a certain runlevel, first create a startup script for the service and place it in the directory /etc/rc.d/init.d or /etc/init.d (depending on how your distribution lays out these directories). To associate the script with a runlevel, create a symbolic link in the directory for the runlevel you wish it to be started under. The filename of this symbolic link should be prefixed with SXX where XX is a number. The purpose of the number is to control the order in which scripts are executed within each runlevel. The scripts are executed in ascending numerical order. An example of adding an initialisation script to a runlevel is:
$ cp myservice /etc/init.d/
$ ln -s /etc/init.d/myservice /etc/rc3.d/S99myservice
The next time runlevel 3 is entered, myservice would be started.
Booting into a runlevel
You can change the runlevel Linux boots into by specifying it at boot time. If your system uses LILO, append the runlevel to the boot command as shown:
LILO: linux 5
If your system uses GRUB, you can change the boot runlevel by pressing the ‘e’ key to edit the boot configuration. From here, append the runlevel to the end of the boot command as shown:
kernel /vmlinuz ro root=/dev/hda1 5