file-systems: Use cgroups v2.

cgroup v2 is the next generation of the control groups API.  This patch
replaces the cgroup v1 file systems with the unified cgroup v2 file
system.

cgroup v2 allows for things like containerd/podman to run rootless
containers and opens guix system up to running things like Kubernetes.

Thanks to Hilton Chain <hako@ultrarare.space> for suggesting the Docker
service change.

* gnu/system/file-systems.scm (%control-groups): Change to a single
"cgroup2" mount point.
* gnu/services/docker.scm (docker-shepherd-service): Trim 'requirement'
field accordingly.

Co-authored-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
Sam Lockart 2023-06-24 03:11:26 +00:00 committed by Ludovic Courtès
parent 267e4234ff
commit 969cea6836
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 8 additions and 26 deletions

View file

@ -116,12 +116,7 @@ (define (docker-shepherd-service config)
(requirement '(containerd (requirement '(containerd
dbus-system dbus-system
elogind elogind
file-system-/sys/fs/cgroup/blkio file-system-/sys/fs/cgroup
file-system-/sys/fs/cgroup/cpu
file-system-/sys/fs/cgroup/cpuset
file-system-/sys/fs/cgroup/devices
file-system-/sys/fs/cgroup/memory
file-system-/sys/fs/cgroup/pids
networking networking
udev)) udev))
(start #~(make-forkexec-constructor (start #~(make-forkexec-constructor

View file

@ -445,26 +445,13 @@ (define %immutable-store
(flags '(read-only bind-mount no-atime)))) (flags '(read-only bind-mount no-atime))))
(define %control-groups (define %control-groups
(let ((parent (file-system ;; The cgroup2 file system.
(device "cgroup") (list (file-system
(mount-point "/sys/fs/cgroup") (device "none")
(type "tmpfs") (mount-point "/sys/fs/cgroup")
(check? #f)))) (type "cgroup2")
(cons parent (check? #f)
(map (lambda (subsystem) (create-mount-point? #f))))
(file-system
(device "cgroup")
(mount-point (string-append "/sys/fs/cgroup/" subsystem))
(type "cgroup")
(check? #f)
(options subsystem)
(create-mount-point? #t)
;; This must be mounted after, and unmounted before the
;; parent directory.
(dependencies (list parent))))
'("cpuset" "cpu" "cpuacct" "memory" "devices" "freezer"
"blkio" "perf_event" "pids")))))
(define %elogind-file-systems (define %elogind-file-systems
;; We don't use systemd, but these file systems are needed for elogind, ;; We don't use systemd, but these file systems are needed for elogind,