mirror of
https://github.com/containers/podman.git
synced 2025-10-17 03:04:21 +08:00
Add --sync option to podman rm
With the changes made recently to ensure Podman does not hit the OCI runtime as often to sync state, we can find ourselves in a situation where the runtime's state does not match ours. Add a --sync flag to podman rm to ensure we can still remove containers when this happens. Signed-off-by: Matthew Heon <mheon@redhat.com>
This commit is contained in:
@ -675,22 +675,22 @@ func (c *Container) Batch(batchFunc func(*Container) error) error {
|
||||
return err
|
||||
}
|
||||
|
||||
// Sync updates the current state of the container, checking whether its state
|
||||
// has changed
|
||||
// Sync can only be used inside Batch() - otherwise, it will be done
|
||||
// automatically.
|
||||
// When called outside Batch(), Sync() is a no-op
|
||||
// Sync updates the status of a container by querying the OCI runtime.
|
||||
// If the container has not been created inside the OCI runtime, nothing will be
|
||||
// done.
|
||||
// Most of the time, Podman does not explicitly query the OCI runtime for
|
||||
// container status, and instead relies upon exit files created by conmon.
|
||||
// This can cause a disconnect between running state and what Podman sees in
|
||||
// cases where Conmon was killed unexpected, or runc was upgraded.
|
||||
// Running a manual Sync() ensures that container state will be correct in
|
||||
// such situations.
|
||||
func (c *Container) Sync() error {
|
||||
if !c.batched {
|
||||
return nil
|
||||
}
|
||||
|
||||
// If runtime knows about the container, update its status in runtime
|
||||
// And then save back to disk
|
||||
if (c.state.State != ContainerStateUnknown) &&
|
||||
(c.state.State != ContainerStateConfigured) {
|
||||
(c.state.State != ContainerStateConfigured) &&
|
||||
(c.state.State != ContainerStateExited) {
|
||||
oldState := c.state.State
|
||||
// TODO: optionally replace this with a stat for the exit file
|
||||
if err := c.runtime.ociRuntime.updateContainerStatus(c, true); err != nil {
|
||||
return err
|
||||
}
|
||||
|
Reference in New Issue
Block a user