Rootless vs Rootfull

In the Podman world, non-privileged users can run containers on their own: those are the so-called rootless containers. In NethServer 8, we borrow the same word from Podman and use it in the context of modules, together with its opposite, rootfull.

To inspect a rootless module start Bash with the runagent command to properly initialize the Systemd runtime environment. For instance, to check if Traefik is running:

runagent -m traefik1
# A Bash prompt from traefik1's session appears
systemctl --user status traefik
# Systemctl prints its output

If you type the above commands in the same line, runagent executes systemctl without forking an interactive Bash shell:

runagent -m traefik1 systemctl --user status traefik
# Systemctl prints its output from traefik1's session

Let’s see the differences of rootless modules vs rootfull modules.

Unix user

The main difference between rootless and rootfull modules, as suggested by the adjective, is the Unix user running the module processes and its system privileges.

Rootfull: module containers run as root (EUID 0).

Rootless: module containers run as a normal Unix user. The Unix user account is created by the node agent when the module instance is added. It has session lingering enabled: it automatically starts a persistent Systemd user manager instance at system boot.

To check if a module is rootless or not, in Python write:

import os
if os.geteuid() == 0:
    print('ROOTFULL')
else:
    print('ROOTLESS')

Same thing, in Bash:

if [[ $EUID == 0 ]]; then
    echo ROOTFULL
else
    echo ROOTLESS
fi

As alternative print the effective user ID with

id -u

Filesystem paths

The two types of modules have a similar filesystem structure. Rootless modules are installed to /home/<module_id>/.config, whilst rootfull are installed to /var/lib/nethserver/<module_id>.

Systemd units

Rootless modules also have Systemd user units installed under ~/.config/systemd/user. Recall that some system-wide user units are installed by the core under /etc/systemd/user. When running the systemctl command, add the --user flag. Eg.

systemctl --user status traefik

Rootfull modules share the system-wide Systemd directories. Their units are installed under /etc/systemd/system. As they share the same directory, unit files must be named as <module_id> or they must use the <module_id>- prefix to avoid naming clashes with other instances of the same module. Eg:

cat /etc/systemd/system/samba1.service
systemctl start samba1

Volumes

Rootfull modules share the same Podman volumes namspace. As consequence, rootfull modules must use the <module_id>- prefix for their volume names to avoid volume naming clashes. Eg.

samba1-data
samba1-config

Rootless modules can use any volume name because the Podman volume namespace is private for the module.

This command prints out the filesystem path where Podman stores volumes data:

podman system info --format='{{.Store.VolumePath}}'