Skip to content

Commit

Permalink
Print hints if kernel.apparmor_restrict_unprivileged_userns is set
Browse files Browse the repository at this point in the history
For containerd/nerdctl issue 2847, moby/moby issue 47480

Signed-off-by: Akihiro Suda <[email protected]>
  • Loading branch information
AkihiroSuda committed Mar 1, 2024
1 parent efee459 commit 33c3e7c
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 0 deletions.
1 change: 1 addition & 0 deletions pkg/parent/parent.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,7 @@ func Parent(opt Opt) error {
cmd.Env = append(cmd.Env, fmt.Sprintf("%s=%d", opt.ParentEGIDEnvKey, os.Getegid()))
}
if err := cmd.Start(); err != nil {
warnOnChildStartFailure(err)
return fmt.Errorf("failed to start the child: %w", err)
}

Expand Down
45 changes: 45 additions & 0 deletions pkg/parent/warn.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
package parent

import (
"errors"
"os"
"strconv"
"strings"

"github.com/moby/sys/mountinfo"
"github.com/sirupsen/logrus"
"golang.org/x/sys/unix"
)

func warnPropagation(propagation string) {
Expand Down Expand Up @@ -57,3 +59,46 @@ func warnSysctl() {
}
}
}

func warnOnChildStartFailure(childStartErr error) {
if errors.Is(childStartErr, unix.EACCES) {
// apparmor_restrict_unprivileged_userns is available since Ubuntu 23.10.
// Enabled by default since Ubuntu 24.04.
// https://github.com/containerd/nerdctl/issues/2847
b, err := os.ReadFile("/proc/sys/kernel/apparmor_restrict_unprivileged_userns")
if err == nil {
s := strings.TrimSpace(string(b))
i, err := strconv.ParseInt(s, 10, 64)
if err != nil {
logrus.WithError(err).Warnf("Failed to parse /proc/sys/kernel/apparmor_restrict_unprivileged_userns (%q)", s)
} else if i == 1 {
logrus.WithError(childStartErr).Warnf("This error might have happened because /proc/sys/kernel/apparmor_restrict_unprivileged_userns is set to 1")
selfExe, err := os.Executable()
if err != nil {
selfExe = "/usr/local/bin/rootlesskit"
logrus.WithError(err).Warnf("Failed to detect the path of the rootlesskit binary, assuming it to be %q", selfExe)
}
profileName := strings.ReplaceAll(strings.TrimPrefix(selfExe, "/"), "/", ".")
const tmpl = `
########## BEGIN ##########
cat <<EOT | sudo tee "/etc/apparmor.d/%s"
# ref: https://ubuntu.com/blog/ubuntu-23-10-restricted-unprivileged-user-namespaces
abi <abi/4.0>,
include <tunables/global>
%s flags=(unconfined) {
userns,
# Site-specific additions and overrides. See local/README for details.
include if exists <local/%s>
}
EOT
sudo systemctl restart apparmor.service
########## END ##########
`
logrus.Warnf("Hint: try running the following commands:\n"+tmpl+"\n", profileName, selfExe, profileName)
}
}
}
}

0 comments on commit 33c3e7c

Please sign in to comment.