From 3852184d02aed3d4d78d927da4fe878b5da7dac7 Mon Sep 17 00:00:00 2001 From: Daniel J Walsh Date: Thu, 21 Jan 2021 08:29:21 -0500 Subject: [PATCH] Pick default OCI Runtime from containers.conf Currently we have a weird situation where the user sets the default runtime in his containers.conf for podman but Buildah is still falling back to use crun because it was hard coded as the default for Buildah. We are changing the default to "crun" but this should ONLY be used when the containers.conf load fails, which should never happen. I would like to remove this default, but that would theoretically break the API promise of Buildah. This should fix https://github.com/containers/podman/issues/8893 Signed-off-by: Daniel J Walsh --- util/types.go | 5 +++-- util/util.go | 9 +++++++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/util/types.go b/util/types.go index dc5f4b6c8e7..49f4989cae1 100644 --- a/util/types.go +++ b/util/types.go @@ -1,8 +1,9 @@ package util const ( - // DefaultRuntime is the default command to use to run the container. - DefaultRuntime = "runc" + // DefaultRuntime should no longer be used. + // Default runtime should come from containers.conf + DefaultRuntime = "crun" // DefaultCNIPluginPath is the default location of CNI plugin helpers. DefaultCNIPluginPath = "/usr/libexec/cni:/opt/cni/bin" // DefaultCNIConfigDir is the default location of CNI configuration files. diff --git a/util/util.go b/util/util.go index 99f68d9e1ce..5b512a4540e 100644 --- a/util/util.go +++ b/util/util.go @@ -260,10 +260,15 @@ func Runtime() string { // Need to switch default until runc supports cgroups v2 if unified, _ := IsCgroup2UnifiedMode(); unified { - return "crun" + return } - return DefaultRuntime + conf, err := config.Default() + if err != nil { + logrus.Debugf("Error loading container config when searching for local runtime.") + return "DefaultRuntime" + } + return conf.Engine.OCIRuntime } // StringInSlice returns a boolean indicating if the exact value s is present