OpenRC: Difference between revisions
| Kittenface (talk | contribs)  (→Quick-Start Information:  Moved the descriptions above the commands and the bullet points to be more clear after accidently changing my runlevel. (I used U+21D4 because Mediawiki doesn't like the ascii version "<=>".)) | Prabuanand (talk | contribs)   (added reference to busybox init) | ||
| (109 intermediate revisions by 14 users not shown) | |||
| Line 1: | Line 1: | ||
| Alpine Linux uses [https://github.com/OpenRC/ OpenRC] for its [https://en.wikipedia.org/wiki/Init init] system. The init system manages the services, including the boot and shutdown of your system. OpenRC also supports managing [[#User services|services for users]].   | |||
| Alpine Linux uses [https:// | |||
| To learn the basics of OpenRC quickly, refer to the [https://docs.alpinelinux.org/user-handbook/0.1a/Working/openrc.html working with OpenRC] guide from the Alpine Linux documentation project.   | |||
| == Quickstart  == | |||
| {|align="center" style="width:100%; border:1px #0771a6 solid; background:#f9f9f9; text-align:left; border-collapse:collapse;" | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | width="50%" |Action | |||
| |             |Command | |||
| |- | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" | '''Managing a service - start,stop and restart''' | |||
| |- | |||
| | Start {{ic|ServiceName}} now || {{Cmd|# rc-service <var>ServiceName</var> start}} | |||
| |- | |||
| | Stop {{ic|ServiceName}} now || {{Cmd|# rc-service <var>ServiceName</var> stop}}  | |||
| |- | |||
| | Restart {{ic|ServiceName}} now || {{Cmd|# rc-service <var>ServiceName</var> restart}}  | |||
| |- | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" | '''Adding and removing service from runlevels''' | |||
| |- | |||
| | Add {{ic|ServiceName}} to {{ic|runlevel}} || {{Cmd|# rc-update add <var>ServiceName</var> <var>runlevel</var>}}  | |||
| |- | |||
| | Remove {{ic|ServiceName}} from {{ic|runlevel}} || {{Cmd|# rc-update del <var>ServiceName</var> <var>runlevel</var>}}  | |||
| |- | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" | ''' Check services in a runlevel and their status''' | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| |- | |||
| | To check status of {{ic|ServiceName}} || {{Cmd|$ rc-service <var>ServiceName</var> status}}  | |||
| |- | |||
| | To view services configured at {{ic|runlevel}}  || {{Cmd|$ rc-update show <var>runlevel</var>}}  | |||
| |- | |||
| | To view currently active runlevels and state of services  || {{Cmd|$ rc-status}}  | |||
| |- | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" | ''' Check and manage runlevels''' | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| |- | |||
| | To view available runlevels || {{Cmd|$ rc-status -l}}  | |||
| |- | |||
| | To change to a different {{ic|runlevel}} || {{Cmd|# openrc <var>runlevel</var>}}  | |||
| |- | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" | ''' Stacked runlevels''' | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| |- | |||
| | To add {{ic|s-runlevel}} as a stacked {{ic|runlevel}} || {{Cmd|# rc-update add -s <var>s-runlevel</var> <var>runlevel</var>}}  | |||
| |- | |||
| | To remove {{ic|s-runlevel}} as a stacked {{ic|runlevel}} || {{Cmd|# rc-update del -s <var>s-runlevel</var> <var>runlevel</var>}} | |||
| |  | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| | colspan="3" |'''User Services''' | |||
| |- style="background:#333333; color:#ffffff; font-size: 0.9em; text-align:center;" | |||
| |- | |||
| | To view currently active user runlevels and state of user services ({{ic|-U}}) || {{Cmd|$ rc-status -U}}  | |||
| |- | |||
| | To change to a different user {{ic|runlevel}} || {{Cmd|$ openrc -U </var>runlevel</var>}}  | |||
| |- | |||
| | Add user {{ic|ServiceName}} to user {{ic|runlevel}} || {{Cmd|$ rc-update -U add <var>ServiceName</var> <var>runlevel</var>}} | |||
| |- | |||
| | To add {{ic|s-runlevel}}as a stacked user {{ic|runlevel}} || {{Cmd|$ rc-update -U add -s <var>s-runlevel</var> <var>runlevel</var>}}  | |||
| |} | |||
| == Runlevels == | |||
| {{ | The [[BusyBox#init|BusyBox init]] executes [[OpenRC]] runlevel scripts according to entries in {{Path|/etc/inittab}}. A ''runlevel'' is basically a collection of services that needs to be started when certain conditions are met. Instead of using runlevel numbers, such as is used traditionally with ''SysV'' init, these are named, and users can create their own, if needed. The default startup uses the '''sysinit''', '''boot''', and '''default''' runlevels, in that order. Shutdown uses the '''shutdown''' runlevel. | ||
| The available runlevels are: | The available runlevels are: | ||
| * '''default''' - Used if no runlevel is specified. (This is generally the runlevel you want to add services to.) | * '''default''' - Used if no runlevel is specified. (This is generally the runlevel you want to add services to.) | ||
| Line 28: | Line 75: | ||
| The special runlevels are: | The special runlevels are: | ||
| * '''sysinit''' - Brings up system specific stuff such as <code>/dev</code>, <code>/proc</code> and optionally <code>/sys</code> for Linux based systems. It also mounts <code>/lib/rc/init.d</code> as a ramdisk using tmpfs where available unless <code>/</code> is mounted rw at boot. <code>'''rc'''</code> uses <code>/lib/rc/init.d</code> to hold state information about the services it runs. '''sysinit''' always runs when the host first starts and should not be run again. | |||
| * '''boot''' - Generally, the only services that one should add to the '''boot''' runlevel are those which deal with the mounting of filesystems, setting the initial state of attached peripherals, and logging. Hotplugged services are added to the '''boot''' runlevel by the system. All services in the '''boot''' and '''sysinit''' runlevels are automatically included in all other runlevels except for those listed here. | |||
| * '''single''' - Stops all services except for those in the '''sysinit''' runlevel. | |||
| * '''reboot''' - Changes to the '''shutdown''' runlevel, and then reboots the host. | |||
| * '''shutdown''' - Changes to the shutdown '''runlevel''', and then halts the host. | |||
| ==  | === Stacked runlevels === | ||
| ''Stacked'' runlevels allows for the "inheritance" of services. A few use cases are given below:- | |||
| * [https://docs.alpinelinux.org/user-handbook/0.1a/Working/openrc.html#_runlevel_stacking Running an office runlevel with VPN service] | |||
| * [[#Preventing slow services from delaying system startup|Preventing slow services from delaying system startup]] | |||
| For more detailed information, refer [https://wiki.gentoo.org/wiki/OpenRC/Stacked%20runlevel Gentoo wiki]. | |||
| ==  | == Config files ==   | ||
| The main configuration file for OpenRC is {{Path|/etc/rc.conf}}. The OpenRC service scripts for each service can be found at {{Path|/etc/init.d/}} and their respective service configuration files at {{Path|/etc/conf.d/}}. | |||
| [[Category:Booting]] | == Command usage == | ||
| OpenRC provides the following commands: | |||
| * {{ic|rc-update}}  | |||
| * {{ic|rc-service}} | |||
| * {{ic|rc-status}} | |||
| * {{ic|openrc}} | |||
| To view the command usage for all OpenRC commands, use the '''--help''' or '''-h''' flag.  For example: {{ic|$ rc-update '''--help'''}} or {{ic|$ rc-update '''-h'''}} will show usage information for {{ic|rc-update}}. | |||
| To {{ic|start}}, {{ic|stop}} or {{ic|restart}} a service {{ic|ServiceName}} immediately at the current runlevel:- | |||
| {{Cmd|$ doas rc-service <var>ServiceName</var> start}} | |||
| {{Cmd|$ doas rc-service <var>ServiceName</var> stop}} | |||
| To {{ic|add}} or {{ic|delete}} a service to/from the sequence of services that need to start automatically in future sessions at the {{ic|boot}} runlevel:  | |||
| {{Cmd|$ doas rc-update add <var>ServiceName</var> boot}} | |||
| Note that the {{ic|'''default'''}} runlevel is assumed, so it does not need to be stated explicitly: | |||
| {{Cmd|$ doas rc-update add <var>ServiceName</var>}} | |||
| {{Cmd|$ doas rc-update del <var>ServiceName</var>}} | |||
| List the current status of all services; to display the status of all ''user services'' add '''-U''' : | |||
| {{Cmd|$ rc-status}} | |||
| List the assigned runlevels of all services; to display the runlevels of ''user services'' add '''-U''' : | |||
| {{Cmd|$ rc-update}} | |||
| Refer to the [https://github.com/OpenRC/openrc/blob/master/user-guide.md OpenRC user guide] for more detailed information. | |||
| == Cgroups == | |||
| Alpine Linux uses [https://www.kernel.org/doc/html/latest/admin-guide/cgroup-v2.html Cgroups version 2], or '''unified''', as the default cgroup mode in OpenRC since [[Release_Notes_for_Alpine_3.19.0#cgroups_v2|v3.19]].  | |||
| To start {{ic|cgroups}} service:{{Cmd|# rc-service cgroups start}}  | |||
| To enable cgroups and auto mount the cgroup filesystem on boot {{Cmd|# rc-update add cgroups}} | |||
| To enable ''hybrid'' cgroups, the previous default, edit the file {{Path|/etc/rc.conf}} and change the setting for {{ic|rc_cgroup_mode}} as follows:{{Cat|/etc/rc.conf|rc_cgroup_mode{{=}}"hybrid"}} | |||
| == Local service == | |||
| Use the {{Path|/etc/local.d/}} directory to place programs or scripts which are to be run when the {{ic|local}} service is started or stopped. | |||
| If a file in this directory is executable and it has a .start extension, it will be run when the local service is started. If a file is executable and it has a .stop extension, it will be run when the local service is stopped. For more info refer [https://github.com/OpenRC/openrc/blob/master/local.d/README README] | |||
| To enable the {{ic|local}} service, issue the command:{{Cmd|# rc-update add local}} | |||
| == Preventing slow services from delaying system startup == | |||
| Services that take a while to start will block the boot process until they complete. E.g.: {{ic|iwd}},{{ic|networking}},{{ic|chrony}} etc... might delay startup of an interactive system rather than start in the background.  | |||
| === Parallel services ===  | |||
| If the setting {{Codeline|rc_parallel{{=}}"YES"}} is configured, the OpenRC system tries to start services in parallel for a slight speed improvement.  | |||
| This setting however comes with a message from openRC developers:{{Warning|whilst we have improved parallel, it can still potentially lock the boot process. Don't file bugs about this.}}  | |||
| === Stacked runlevel method ===  | |||
| Slow services can also be [https://ptrcnull.me/posts/openrc-async-services.html started after login prompt] using [[#Stacked runlevels|stacked runlevels]].  | |||
| {{Warning|Editing the file {{Path|'''/etc/inittab'''}} wrongly will render the system unusable. Take backup and learn to restore it using rescue disk before proceeding.}} | |||
| # Create a custom runlevel '''async''': {{Cmd|# mkdir /etc/runlevels/async}} | |||
| # Add '''default''' as a stacked runlevel {{Cmd|# rc-update add -s default async}} | |||
| # Remove slow service from '''default''' runlevel and add them to the '''async''' runlevel: {{Cmd|# rc-update del <var>ServiceName</var> default}} {{Cmd|# rc-update add <var>ServiceName</var> async}} | |||
| # Enable the '''async''' runlevel by adding the line '''::once:/sbin/openrc async''' to {{Path|/etc/inittab}} file as follows: {{Cat|/etc/inittab|<nowiki>... | |||
| ::wait:/sbin/openrc default | |||
| ::once:/sbin/openrc async -q | |||
| # Set up a couple of getty's | |||
| tty1::respawn:/sbin/getty 38400 tty1 | |||
| ...</nowiki>}} | |||
| After rebooting, services from '''async''' will start separately. Other services started in '''default''' runlevel may still block [[TTY_Autologin|agetty]] from running, due to the {{ic|wait}} label. | |||
| == User services == | |||
| OpenRC supports managing services for users. User services are currently experimental and available from [[Release_Notes_for_Alpine_3.22.0#OpenRC_User_services|v3.22]]. Here is the [https://pkgs.alpinelinux.org/contents?file=*&path=%2Fetc%2Fuser%2Finit.d&name=&branch=edge&repo=&arch=x86_64 list of OpenRC User services] available currently. | |||
| Such services are said to be running in ''user mode'' and are managed with usual OpenRC commands using the  '''-U''' option (as distinct from the ''-u'' option), and without '''doas''' (nor as root).   | |||
| === Prerequisites === | |||
| * [[XDG_RUNTIME_DIR]] variable must be set  | |||
| === Config files for user services === | |||
| OpenRC uses {{path|$XDG_CONFIG_HOME/rc}} for its user service configuration. If <code>$XDG_CONFIG_HOME</code> is unset, the fallback {{path|~/.config}} is used. | |||
| The main configuration file for OpenRC User services is {{path|~/.config/rc/rc.conf}}. | |||
| ==== Runlevels ==== | |||
| Runlevels are represented by directories in {{path|$XDG_CONFIG_HOME/rc/runlevels}}. The default runlevel is <code>sysinit</code> and needs to be created explicitly in order to be enabled: | |||
| {{Cmd|$ mkdir -p ${XDG_CONFIG_HOME:-~/.config}/rc/runlevels/sysinit}} | |||
| To start the default runlevel (<code>sysinit</code>), use: | |||
| {{Cmd|$ openrc -U}} | |||
| To start another runlevel, use: | |||
| {{Cmd|$ openrc -U $RUNLEVEL}} | |||
| Add the above line to <code>~/.profile</code> to automatically start the runlevel after logging in. | |||
| If automatic start-up of a runlevel needs to be enforced by the system administrator, see [[#PAM support|PAM support]] below. | |||
| ==== Services ==== | |||
| The service scripts for each OpenRC user service provided as part of official packages can be found at {{Path|/etc/user/init.d/}} and their respective service configuration files at {{Path|/etc/user/conf.d/}}.  | |||
| The folders {{path|~/.config/rc/init.d/}} and {{path|~/.config/rc/conf.d/}} can have user customized service scripts for User services and their respective configuration files. These scripts override official files at {{Path|/etc/user/}}, if their service names match. | |||
| === Configure environment variables === | |||
| ==== For Wayland ==== | |||
| {{Tip|User services like {{pkg|wlsunset}} depend on the {{ic|$WAYLAND_DISPLAY}} environment variable. Hence, it is [https://gitlab.alpinelinux.org/alpine/aports/-/issues/17375#note_530383 recommended] to use '''gui''' runlevel for such services. Even though [[PipeWire]] can run at '''default''' runlevel, ensure that all your User services can run at the chosen runlevel.}}  | |||
| * Allow propagation of the {{ic|$WAYLAND_DISPLAY}} and associated environment variables by adding the following lines to file {{path|~/.config/rc/rc.conf}} as follows:{{Cat|~/.config/rc/rc.conf|<nowiki>rc_env_allow="WAYLAND_DISPLAY"</nowiki>}} | |||
| * Create a custom '''gui''' user runlevel:{{Cmd|$ mkdir -p ~/.config/rc/runlevels/gui}} | |||
| * To start '''gui''' user runlevel, add the line {{ic|openrc -U gui}} to the startup file of your compositor. For eg, for [[Sway]] add:{{Cat|~/.config/sway/config|... | |||
| exec openrc -U gui}} | |||
| ==== For Xorg ==== | |||
| If [[Elogind]] is not used, ensure that [[Wayland#Creating_and_exporting_XDG_RUNTIME_DIR_manually|XDG_RUNTIME_DIR]] is set manually in {{path|~/.xinitrc}}. For eg, for [[dwm]] add:{{Cat|~/.xinitrc|<nowiki>... | |||
| if [ -z "$XDG_RUNTIME_DIR" ]; then | |||
| 	XDG_RUNTIME_DIR="/tmp/$(id -u)-runtime-dir" | |||
| 	mkdir -pm 0700 "$XDG_RUNTIME_DIR" | |||
| 	export XDG_RUNTIME_DIR | |||
| fi | |||
| openrc -U default | |||
| exec dwm</nowiki>}}  | |||
| {{Note|For both the above cases, logout and login for the OpenRC user services to be started, before proceeding further.}} | |||
| === User service management === | |||
| Issue the command {{ic|$ rc-status -Ur}} to view and verify the current user runlevel as '''gui''' and '''default''' for Wayland and Xorg, respectively, before proceeding.  | |||
| To start {{ic|ServiceName}} user service, issue the command:{{Cmd|$ rc-service -U <var>ServiceName</var> start}} | |||
| Verify that the above OpenRC user service is started before proceeding further: {{Cmd|$ rc-status -U}}  | |||
| To enable {{ic|ServiceName}} user service, issue the command: {{Cmd|$ rc-update -U add <var>ServiceName</var>}} | |||
| {{Tip|Once a user service is configured, to prevent duplicate instance, remove them from {{Path|/etc/xdg/autostart}} folder or from the startup/config file.}} | |||
| === PAM support === | |||
| The default installation of OpenRC user services in Alpine Linux is without PAM support. | |||
| In scenarios where services should not be allowed to [https://wiki.gentoo.org/wiki/OpenRC#lingering linger] on logout, PAM support for OpenRC user services can be enabled by installing the {{pkg|openrc-user-pam}} package.{{Cmd|# apk add openrc-user-pam}} | |||
| == Troubleshooting == | |||
| Whenever a openRC service fails to run, troubleshoot by enabling a debugging option, and then run the command.  | |||
| For example, if running the command {{ic|rc-service <var>greetd</var> start}} causes the [[Greetd|greetd]] service to immediately crash, then alter the command to enable debug and to view its output:{{Cmd|# rc-service -d <var>greetd</var> restart}} | |||
| === XDG_RUNTIME_DIR unset === | |||
| While configuring [[#User services|user services]], running the command {{ic|$ doas rc-update add -U pipewire gui}} will generate the above error {{ic|XDG_RUNTIME_DIR unset}}.  Always issue the command as normal user {{ic|$ rc-update add -U pipewire gui}} and do NOT use {{ic|doas}}.  | |||
| === ERROR: user.greetd failed to start === | |||
| While using [[#User services|user services]] with [[greetd]], the above error message will appear. This failed error message for {{ic|user.greetd}} service is harmless as per {{MR|81612#note_492385}}. | |||
| === failed to create display === | |||
| When using openRC user services for {{ic|wlsunset}}, the following  error message may appear:{{Cmd|daemon.err wlsunset: failed to create display}}You will need the GUI runlevel for services that depend on {{ic|$WAYLAND_DISPLAY}}. Refer [[#For Wayland| Configure environment variables For Wayland]] section. | |||
| == See also == | |||
| * [[Writing Init Scripts]] | |||
| * [[Multiple Instances of Services]] | |||
| * [https://github.com/OpenRC/openrc/blob/master/user-guide.md OpenRC user Guide] | |||
| * [https://github.com/OpenRC/openrc/blob/master/service-script-guide.md OpenRC Service Script Writing Guide] | |||
| * [https://wiki.gentoo.org/wiki/OpenRC Gentoo Wiki] | |||
| * [https://wiki.archlinux.org/title/OpenRC ArchWiki] | |||
| * [https://wiki.postmarketos.org/wiki/OpenRC PostmarketOS Wiki] | |||
| * [https://ptrcnull.me/posts/openrc-async-services.html Start services after login prompt] | |||
| [[Category:Booting]]  | |||
| [[Category:System Administration]] | |||
| [[Category:Services]] | |||
Latest revision as of 11:40, 25 September 2025
Alpine Linux uses OpenRC for its init system. The init system manages the services, including the boot and shutdown of your system. OpenRC also supports managing services for users.
To learn the basics of OpenRC quickly, refer to the working with OpenRC guide from the Alpine Linux documentation project.
Quickstart
| Action | Command | |
| Managing a service - start,stop and restart | ||
| Start ServiceNamenow | # rc-service ServiceName start | |
| Stop ServiceNamenow | # rc-service ServiceName stop | |
| Restart ServiceNamenow | # rc-service ServiceName restart | |
| Adding and removing service from runlevels | ||
| Add ServiceNametorunlevel | # rc-update add ServiceName runlevel | |
| Remove ServiceNamefromrunlevel | # rc-update del ServiceName runlevel | |
| Check services in a runlevel and their status | ||
| To check status of ServiceName | $ rc-service ServiceName status | |
| To view services configured at runlevel | $ rc-update show runlevel | |
| To view currently active runlevels and state of services | $ rc-status | |
| Check and manage runlevels | ||
| To view available runlevels | $ rc-status -l | |
| To change to a different runlevel | # openrc runlevel | |
| Stacked runlevels | ||
| To add s-runlevelas a stackedrunlevel | # rc-update add -s s-runlevel runlevel | |
| To remove s-runlevelas a stackedrunlevel | # rc-update del -s s-runlevel runlevel | |
| User Services | ||
| To view currently active user runlevels and state of user services ( -U) | $ rc-status -U | |
| To change to a different user runlevel | $ openrc -U runlevel | |
| Add user ServiceNameto userrunlevel | $ rc-update -U add ServiceName runlevel | |
| To add s-runlevelas a stacked userrunlevel | $ rc-update -U add -s s-runlevel runlevel | |
Runlevels
The BusyBox init executes OpenRC runlevel scripts according to entries in /etc/inittab. A runlevel is basically a collection of services that needs to be started when certain conditions are met. Instead of using runlevel numbers, such as is used traditionally with SysV init, these are named, and users can create their own, if needed. The default startup uses the sysinit, boot, and default runlevels, in that order. Shutdown uses the shutdown runlevel.
The available runlevels are:
- default - Used if no runlevel is specified. (This is generally the runlevel you want to add services to.)
- hotplugged
- manual
The special runlevels are:
- sysinit - Brings up system specific stuff such as /dev,/procand optionally/sysfor Linux based systems. It also mounts/lib/rc/init.das a ramdisk using tmpfs where available unless/is mounted rw at boot.rcuses/lib/rc/init.dto hold state information about the services it runs. sysinit always runs when the host first starts and should not be run again.
- boot - Generally, the only services that one should add to the boot runlevel are those which deal with the mounting of filesystems, setting the initial state of attached peripherals, and logging. Hotplugged services are added to the boot runlevel by the system. All services in the boot and sysinit runlevels are automatically included in all other runlevels except for those listed here.
- single - Stops all services except for those in the sysinit runlevel.
- reboot - Changes to the shutdown runlevel, and then reboots the host.
- shutdown - Changes to the shutdown runlevel, and then halts the host.
Stacked runlevels
Stacked runlevels allows for the "inheritance" of services. A few use cases are given below:-
For more detailed information, refer Gentoo wiki.
Config files
The main configuration file for OpenRC is /etc/rc.conf. The OpenRC service scripts for each service can be found at /etc/init.d/ and their respective service configuration files at /etc/conf.d/.
Command usage
OpenRC provides the following commands:
- rc-update
- rc-service
- rc-status
- openrc
To view the command usage for all OpenRC commands, use the --help or -h flag.  For example: $ rc-update --help or $ rc-update -h will show usage information for rc-update.
To start, stop or restart a service ServiceName immediately at the current runlevel:-
$ doas rc-service ServiceName start
$ doas rc-service ServiceName stop
To add or delete a service to/from the sequence of services that need to start automatically in future sessions at the boot runlevel: 
$ doas rc-update add ServiceName boot
Note that the default runlevel is assumed, so it does not need to be stated explicitly:
$ doas rc-update add ServiceName
$ doas rc-update del ServiceName
List the current status of all services; to display the status of all user services add -U :
$ rc-status
List the assigned runlevels of all services; to display the runlevels of user services add -U :
$ rc-update
Refer to the OpenRC user guide for more detailed information.
Cgroups
Alpine Linux uses Cgroups version 2, or unified, as the default cgroup mode in OpenRC since v3.19.
To start cgroups service:
# rc-service cgroups start
To enable cgroups and auto mount the cgroup filesystem on boot
# rc-update add cgroups
To enable hybrid cgroups, the previous default, edit the file /etc/rc.conf and change the setting for rc_cgroup_mode as follows:
Contents of /etc/rc.conf
Local service
Use the /etc/local.d/ directory to place programs or scripts which are to be run when the local service is started or stopped.
If a file in this directory is executable and it has a .start extension, it will be run when the local service is started. If a file is executable and it has a .stop extension, it will be run when the local service is stopped. For more info refer README
To enable the local service, issue the command:
# rc-update add local
Preventing slow services from delaying system startup
Services that take a while to start will block the boot process until they complete. E.g.: iwd,networking,chrony etc... might delay startup of an interactive system rather than start in the background. 
Parallel services
If the setting rc_parallel="YES" is configured, the OpenRC system tries to start services in parallel for a slight speed improvement.
This setting however comes with a message from openRC developers:

 
Stacked runlevel method
Slow services can also be started after login prompt using stacked runlevels.

- Create a custom runlevel async: # mkdir /etc/runlevels/async 
- Add default as a stacked runlevel # rc-update add -s default async 
- Remove slow service from default runlevel and add them to the async runlevel: # rc-update del ServiceName default # rc-update add ServiceName async 
- Enable the async runlevel by adding the line ::once:/sbin/openrc async to /etc/inittab file as follows: Contents of /etc/inittab ... ::wait:/sbin/openrc default ::once:/sbin/openrc async -q # Set up a couple of getty's tty1::respawn:/sbin/getty 38400 tty1 ...
After rebooting, services from async will start separately. Other services started in default runlevel may still block agetty from running, due to the wait label.
User services
OpenRC supports managing services for users. User services are currently experimental and available from v3.22. Here is the list of OpenRC User services available currently.
Such services are said to be running in user mode and are managed with usual OpenRC commands using the -U option (as distinct from the -u option), and without doas (nor as root).
Prerequisites
- XDG_RUNTIME_DIR variable must be set
Config files for user services
OpenRC uses $XDG_CONFIG_HOME/rc for its user service configuration. If $XDG_CONFIG_HOME is unset, the fallback ~/.config is used.
The main configuration file for OpenRC User services is ~/.config/rc/rc.conf.
Runlevels
Runlevels are represented by directories in $XDG_CONFIG_HOME/rc/runlevels. The default runlevel is sysinit and needs to be created explicitly in order to be enabled:
$ mkdir -p ${XDG_CONFIG_HOME:-~/.config}/rc/runlevels/sysinit
To start the default runlevel (sysinit), use:
$ openrc -U
To start another runlevel, use:
$ openrc -U $RUNLEVEL
Add the above line to ~/.profile to automatically start the runlevel after logging in.
If automatic start-up of a runlevel needs to be enforced by the system administrator, see PAM support below.
Services
The service scripts for each OpenRC user service provided as part of official packages can be found at /etc/user/init.d/ and their respective service configuration files at /etc/user/conf.d/.
The folders ~/.config/rc/init.d/ and ~/.config/rc/conf.d/ can have user customized service scripts for User services and their respective configuration files. These scripts override official files at /etc/user/, if their service names match.
Configure environment variables
For Wayland
$WAYLAND_DISPLAY environment variable. Hence, it is recommended to use gui runlevel for such services. Even though PipeWire can run at default runlevel, ensure that all your User services can run at the chosen runlevel.- Allow propagation of the $WAYLAND_DISPLAYand associated environment variables by adding the following lines to file ~/.config/rc/rc.conf as follows:Contents of ~/.config/rc/rc.conf rc_env_allow="WAYLAND_DISPLAY"
- Create a custom gui user runlevel:$ mkdir -p ~/.config/rc/runlevels/gui 
- To start gui user runlevel, add the line openrc -U guito the startup file of your compositor. For eg, for Sway add:Contents of ~/.config/sway/config ... exec openrc -U gui
For Xorg
If Elogind is not used, ensure that XDG_RUNTIME_DIR is set manually in ~/.xinitrc. For eg, for dwm add:
Contents of ~/.xinitrc
User service management
Issue the command $ rc-status -Ur to view and verify the current user runlevel as gui and default for Wayland and Xorg, respectively, before proceeding. 
To start ServiceName user service, issue the command:
$ rc-service -U ServiceName start
Verify that the above OpenRC user service is started before proceeding further:
$ rc-status -U
 
To enable ServiceName user service, issue the command: 
$ rc-update -U add ServiceName
PAM support
The default installation of OpenRC user services in Alpine Linux is without PAM support.
In scenarios where services should not be allowed to linger on logout, PAM support for OpenRC user services can be enabled by installing the openrc-user-pam package.
# apk add openrc-user-pam
Troubleshooting
Whenever a openRC service fails to run, troubleshoot by enabling a debugging option, and then run the command.
For example, if running the command rc-service greetd start causes the greetd service to immediately crash, then alter the command to enable debug and to view its output:
# rc-service -d greetd restart
XDG_RUNTIME_DIR unset
While configuring user services, running the command $ doas rc-update add -U pipewire gui will generate the above error XDG_RUNTIME_DIR unset.  Always issue the command as normal user $ rc-update add -U pipewire gui and do NOT use doas. 
ERROR: user.greetd failed to start
While using user services with greetd, the above error message will appear. This failed error message for user.greetd service is harmless as per !81612#note_492385.
failed to create display
When using openRC user services for wlsunset, the following  error message may appear:
daemon.err wlsunset: failed to create display
You will need the GUI runlevel for services that depend on $WAYLAND_DISPLAY. Refer  Configure environment variables For Wayland section.