2018-01-12 14:10:42 -06:00
|
|
|
OpenRC Users Guide
|
|
|
|
==================
|
|
|
|
|
2016-02-09 15:30:46 -06:00
|
|
|
# Purpose and description
|
|
|
|
|
|
|
|
OpenRC is an init system for Unixoid operating systems. It takes care of
|
|
|
|
startup and shutdown of the whole system, including services.
|
|
|
|
|
|
|
|
It evolved out of the Gentoo "Baselayout" package which was a custom pure-shell
|
|
|
|
startup solution. (This was both hard to maintain and debug, and not very
|
|
|
|
performant)
|
|
|
|
|
|
|
|
Most of the core parts are written in C99 for performance and flexibility
|
|
|
|
reasons, while everything else is posix sh.
|
|
|
|
The License is 2-clause BSD
|
|
|
|
|
|
|
|
Current size is about 10k LoC C, and about 4k LoC shell.
|
|
|
|
|
|
|
|
OpenRC is known to work on Linux, many BSDs (FreeBSD, OpenBSD, DragonFlyBSD at
|
|
|
|
least) and HURD.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Services are stateful (i.e. `start`; `start` will lead to "it's already started")
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
# Startup
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Usually PID1 (aka. `init`) calls the OpenRC binary (`/sbin/openrc` by default).
|
2016-02-09 15:30:46 -06:00
|
|
|
(The default setup assumes sysvinit for this)
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
openrc scans the runlevels (default: `/etc/runlevels`) and builds a dependency
|
2016-02-09 15:30:46 -06:00
|
|
|
graph, then starts the needed service scripts, either serialized (default) or in
|
|
|
|
parallel.
|
|
|
|
|
2018-01-10 13:25:13 -06:00
|
|
|
When all the service scripts are started openrc terminates. There is no
|
|
|
|
persistent daemon. (Integration with tools like monit, runit or s6 can be done)
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
# Shutdown
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
On change to runlevel 0/6 or running `reboot`, `halt` etc., openrc stops all
|
|
|
|
services that are started and runs the services in the `shutdown` runlevel.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
# Modifying Service Scripts
|
|
|
|
|
|
|
|
Any service can, at any time, be started/stopped/restarted by executing
|
2016-09-02 14:10:05 +02:00
|
|
|
`rc-service someservice start`, `rc-service someservice stop`, etc.
|
2016-02-09 15:30:46 -06:00
|
|
|
Another, less preferred method, is to run the service script directly,
|
2016-09-02 14:10:05 +02:00
|
|
|
e.g. `/etc/init.d/service start`, `/etc/init.d/service stop`, etc.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
OpenRC will take care of dependencies, e.g starting apache will start network
|
|
|
|
first, and stopping network will stop apache first.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
There is a special command `zap` that makes OpenRC 'forget' that a service is
|
2016-02-09 15:30:46 -06:00
|
|
|
started; this is mostly useful to reset a crashed service to stopped state
|
|
|
|
without invoking the (possibly broken) stop function of the service script.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Calling `openrc` without any arguments will try to reset all services so
|
2016-02-09 15:30:46 -06:00
|
|
|
that the current runlevel is satisfied; if you manually started apache it will be
|
|
|
|
stopped, and if squid died but is in the current runlevel it'll be restarted.
|
|
|
|
|
|
|
|
# Runlevels
|
|
|
|
|
|
|
|
OpenRC has a concept of runlevels, similar to what sysvinit historically
|
|
|
|
offered. A runlevel is basically a collection of services that needs to be
|
|
|
|
started. Instead of random numbers they are named, and users can create their
|
|
|
|
own if needed. This allows, for example, to have a default runlevel with
|
|
|
|
"everything" enabled, and a "powersaving" runlevel where some services are
|
|
|
|
disabled.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
The `rc-status` helper will print all currently active runlevels and the state
|
2018-01-10 13:25:13 -06:00
|
|
|
of services in them:
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
```
|
2016-02-09 15:30:46 -06:00
|
|
|
# rc-status
|
|
|
|
* Caching service dependencies ... [ ok ]
|
|
|
|
Runlevel: default
|
|
|
|
modules [ started ]
|
|
|
|
lvm [ started ]
|
2016-09-02 14:10:05 +02:00
|
|
|
```
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
All runlevels are represented as folders in `/etc/runlevels/` with symlinks to
|
2018-01-10 13:25:13 -06:00
|
|
|
the actual service scripts.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Calling openrc with an argument (`openrc default`) will switch to that
|
2016-02-09 15:30:46 -06:00
|
|
|
runlevel; this will start and stop services as needed.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Managing runlevels is usually done through the `rc-update` helper, but could of
|
2016-02-09 15:30:46 -06:00
|
|
|
course be done by hand if desired.
|
2016-09-02 14:10:05 +02:00
|
|
|
e.g. `rc-update add nginx default` - add nginx to the default runlevel
|
2020-12-04 17:23:18 -08:00
|
|
|
Note: `rc-update` will not start nginx! You'd still have to trigger `rc`, or run
|
|
|
|
the service script by hand, or start it with `rc-service nginx start`.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
FIXME: Document stacked runlevels
|
|
|
|
|
2018-06-05 17:34:09 -05:00
|
|
|
The default startup uses the runlevels `sysinit`, `boot`, and `default`,
|
|
|
|
in that order. Shutdown uses the `shutdown` runlevel.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
# The Magic of `conf.d`
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
Most service scripts need default values. It would be fragile to
|
2016-09-02 14:10:05 +02:00
|
|
|
explicitly source some arbitrary files. By convention `openrc-run` will source
|
|
|
|
the matching file in `/etc/conf.d/` for any script in `/etc/init.d/`
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
This allows you to set random startup-related things easily. Example:
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
```
|
2016-02-09 15:30:46 -06:00
|
|
|
conf.d/foo:
|
|
|
|
START_OPTS="--extraparameter sausage"
|
|
|
|
|
|
|
|
init.d/foo:
|
|
|
|
start() {
|
2020-11-01 20:15:26 +01:00
|
|
|
/usr/sbin/foo-daemon ${START_OPTS}
|
2016-02-09 15:30:46 -06:00
|
|
|
}
|
2016-09-02 14:10:05 +02:00
|
|
|
```
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2018-01-10 13:25:13 -06:00
|
|
|
The big advantage of this split is that most of the time editing of the service
|
2016-02-09 15:30:46 -06:00
|
|
|
script can be avoided.
|
|
|
|
|
|
|
|
# Start-Stop-Daemon
|
|
|
|
|
|
|
|
OpenRC has its own modified version of s-s-d, which is historically related and
|
|
|
|
mostly syntax-compatible to Debian's s-s-d, but has been rewritten from scratch.
|
|
|
|
|
|
|
|
It helps with starting daemons, backgrounding, creating PID files and many
|
|
|
|
other convenience functions related to managing daemons.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
# `/etc/rc.conf`
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
This file manages the default configuration for OpenRC, and it has examples of
|
|
|
|
per-service-script variables.
|
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
Among these are `rc_parallel` (for parallelized startup), `rc_log` (logs all boot
|
2016-02-09 15:30:46 -06:00
|
|
|
messages to a file), and a few others.
|
|
|
|
|
|
|
|
# ulimit and CGroups
|
|
|
|
|
2017-09-14 10:39:38 -05:00
|
|
|
Setting `ulimit` and `nice` values per service can be done through the
|
|
|
|
`rc_ulimit` variable.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2017-09-14 10:39:38 -05:00
|
|
|
Under Linux, OpenRC can use cgroups for process management as well. Once
|
|
|
|
the kernel is configured appropriately, the `rc_cgroup_mode` setting in
|
2020-12-05 20:27:04 +08:00
|
|
|
/etc/rc.conf should be used to control whether cgroups version one,
|
2017-09-14 10:39:38 -05:00
|
|
|
two, or both are used. The default is to use both if they are available.
|
|
|
|
|
|
|
|
By changing certain settings in the service's `conf.d` file limits can be
|
|
|
|
enforced per service. These settings are documented in detail in the
|
|
|
|
default /etc/rc.conf under `LINUX CGROUPS RESOURCE MANAGEMENT`.
|
|
|
|
|
|
|
|
# Dealing with Orphaned Processes
|
|
|
|
|
|
|
|
It is possible to get into a state where there are orphaned processes
|
|
|
|
running which were part of a service. For example, if you are monitoring
|
|
|
|
a service with supervise-daemon and supervise-daemon dies for an unknown
|
|
|
|
reason. The way to deal with this will be different for each system.
|
|
|
|
|
|
|
|
On Linux systems with cgroups enabled, the cgroup_cleanup command is
|
|
|
|
added to all services. You can run it manually, when the service is
|
|
|
|
stopped, by using:
|
|
|
|
|
|
|
|
```
|
|
|
|
# rc-service someservice cgroup_cleanup
|
|
|
|
```
|
|
|
|
|
|
|
|
The `rc_cgroup_cleanup` setting can be changed to yes to make this
|
|
|
|
happen automatically when the service is stopped.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
|
|
|
# Caching
|
|
|
|
|
2018-01-10 13:25:13 -06:00
|
|
|
For performance reasons OpenRC keeps a cache of pre-parsed service metadata
|
2016-09-02 14:10:05 +02:00
|
|
|
(e.g. `depend`). The default location for this is `/${RC_SVCDIR}/cache`.
|
2016-02-09 15:30:46 -06:00
|
|
|
|
2016-09-02 14:10:05 +02:00
|
|
|
The cache uses `mtime` to check for file staleness. Should any service script
|
2016-02-09 15:30:46 -06:00
|
|
|
change it'll re-source the relevant files and update the cache
|
|
|
|
|
|
|
|
# Convenience functions
|
|
|
|
|
|
|
|
OpenRC has wrappers for many common output tasks in libeinfo.
|
|
|
|
This allows to print colour-coded status notices and other things.
|
2018-01-10 13:25:13 -06:00
|
|
|
To make the output consistent the bundled service scripts all use ebegin/eend to
|
2016-02-09 15:30:46 -06:00
|
|
|
print nice messages.
|