Original author(s) | Gerrit Pape |
---|---|
Initial release | February 10, 2004; 21 years ago (2004-02-10)[1] |
Stable release | |
Written in | C,Shell |
Operating system | Linux,FreeBSD,OpenBSD,NetBSD,macOS,Solaris |
Type | Initdaemon |
License | New BSD License |
Website | smarden![]() |
runit is an init and service management scheme forUnix-likeOperating systems that initializes,supervises, and endsprocesses throughout the operating system. Runit is a reimplementation of thedaemontools[3] process supervision toolkit that runs on manyLinux-based operating systems, as well asBSD, andSolaris operating systems. Runit features parallelization of the start up of system services, which can speed up the boot time of the operating system.[4]
When running as aninitdaemon, Runit is the direct or indirectancestor of all other processes. It is the firstprocess started duringbooting, and continues running until the system is shut down. It is often used with other init systems as a separate service manager. In the service manager role, it can be used by unprivileged users to orchestrate personal services, as well as byroot to manage services not otherwise managed by the init system currently in use.
Runit focuses on being a small, modular, andportablecodebase. In the init role, Runit is split into three stages: one time initialization, process supervision, and halting or rebooting. While the first and third stages must be adapted to the specific operating system they are running on, the second stage is portable across allPOSIX compliant operating systems.[4]The 3 stages can be configured through 3 executable files (they are usually shell scripts) named, respectively, 1, 2, and 3.
Stage 2 usually invokes a binary named runsvdir, which is the process responsible for global daemon management: for every daemon it finds in a folder passed to it by argument, it then spawns an individualwatchdog, each of those starts a daemon (and a logger service eventually associated to it) and restarts it if it dies. In case a daemon is added or removed, it kills the watchdog or starts a new one.Executable files with specific names are used to describe the various phases of the daemon's life (run, check, finish, ...), it can intercept signals sent and run by specific scripts if they exist, andnamed pipes are created to exposeinterfaces to control the daemon.
Runit can be used either as a drop-in replacement[5] forsysvinit, or as a service supervisor (with sysvinit as the parentPID 1 process which runs processes specified by the inittab file, or some other init system).[6] The RubyWorks stack of software able to runRuby on Rails incorporated Runit into its suite.[7]
Runit is the default init system of:
Runit is an "officially" available init system for: