mirror of
https://github.com/containers/podman.git
synced 2025-05-19 16:18:51 +08:00
libpod: fix a confusing error message from 'podman system reset' on FreeBSD
This was discovered by a user while testing Podman on FreeBSD (oci-playground/freebsd-podman-testing/issues/17). The error message didn't stop 'podman system reset' from working and this commit simply suppressses the error on FreeBSD. Signed-off-by: Doug Rabson <dfr@rabson.org>
This commit is contained in:
@ -5,14 +5,11 @@ package libpod
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strconv"
|
||||
"syscall"
|
||||
|
||||
"github.com/containers/podman/v5/libpod/define"
|
||||
"github.com/containers/podman/v5/pkg/rootless"
|
||||
"github.com/containers/podman/v5/pkg/util"
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
func (r *Runtime) stopPauseProcess() error {
|
||||
@ -41,80 +38,3 @@ func (r *Runtime) stopPauseProcess() error {
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// Migrate stops the rootless pause process and performs any necessary database
|
||||
// migrations that are required. It can also migrate all containers to a new OCI
|
||||
// runtime, if requested.
|
||||
func (r *Runtime) Migrate(newRuntime string) error {
|
||||
// Acquire the alive lock and hold it.
|
||||
// Ensures that we don't let other Podman commands run while we are
|
||||
// rewriting things in the DB.
|
||||
aliveLock, err := r.getRuntimeAliveLock()
|
||||
if err != nil {
|
||||
return fmt.Errorf("retrieving alive lock: %w", err)
|
||||
}
|
||||
aliveLock.Lock()
|
||||
defer aliveLock.Unlock()
|
||||
|
||||
if !r.valid {
|
||||
return define.ErrRuntimeStopped
|
||||
}
|
||||
|
||||
runningContainers, err := r.GetRunningContainers()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
allCtrs, err := r.state.AllContainers(false)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
logrus.Infof("Stopping all containers")
|
||||
for _, ctr := range runningContainers {
|
||||
fmt.Printf("stopped %s\n", ctr.ID())
|
||||
if err := ctr.Stop(); err != nil {
|
||||
return fmt.Errorf("cannot stop container %s: %w", ctr.ID(), err)
|
||||
}
|
||||
}
|
||||
|
||||
// Did the user request a new runtime?
|
||||
runtimeChangeRequested := newRuntime != ""
|
||||
var requestedRuntime OCIRuntime
|
||||
if runtimeChangeRequested {
|
||||
runtime, exists := r.ociRuntimes[newRuntime]
|
||||
if !exists {
|
||||
return fmt.Errorf("change to runtime %q requested but no such runtime is defined: %w", newRuntime, define.ErrInvalidArg)
|
||||
}
|
||||
requestedRuntime = runtime
|
||||
}
|
||||
|
||||
for _, ctr := range allCtrs {
|
||||
needsWrite := false
|
||||
|
||||
// Reset pause process location
|
||||
oldLocation := filepath.Join(ctr.state.RunDir, "conmon.pid")
|
||||
if ctr.config.ConmonPidFile == oldLocation {
|
||||
logrus.Infof("Changing conmon PID file for %s", ctr.ID())
|
||||
ctr.config.ConmonPidFile = filepath.Join(ctr.config.StaticDir, "conmon.pid")
|
||||
needsWrite = true
|
||||
}
|
||||
|
||||
// Reset runtime
|
||||
if runtimeChangeRequested && ctr.config.OCIRuntime != newRuntime {
|
||||
logrus.Infof("Resetting container %s runtime to runtime %s", ctr.ID(), newRuntime)
|
||||
ctr.config.OCIRuntime = newRuntime
|
||||
ctr.ociRuntime = requestedRuntime
|
||||
|
||||
needsWrite = true
|
||||
}
|
||||
|
||||
if needsWrite {
|
||||
if err := r.state.RewriteContainerConfig(ctr, ctr.config); err != nil {
|
||||
return fmt.Errorf("rewriting config for container %s: %w", ctr.ID(), err)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return r.stopPauseProcess()
|
||||
}
|
||||
|
Reference in New Issue
Block a user