From b57d2f4cc7bb26e8bd2ec4cf4eb66f739ed3beb4 Mon Sep 17 00:00:00 2001 From: Matthew Heon Date: Mon, 23 Sep 2019 14:54:10 -0400 Subject: Force a CNI Delete on refreshing containers CNI expects that a DELETE be run before re-creating container networks. If a reboot occurs quickly enough that containers can't stop and clean up, that DELETE never happens, and Podman currently wipes the old network info and thinks the state has been entirely cleared. Unfortunately, that may not be the case on the CNI side. Some things - like IP address reservations - may not have been cleared. To solve this, manually re-run CNI Delete on refresh. If the container has already been deleted this seems harmless. If not, it should clear lingering state. Fixes: #3759 Signed-off-by: Matthew Heon --- libpod/container_internal_unsupported.go | 4 ++++ 1 file changed, 4 insertions(+) (limited to 'libpod/container_internal_unsupported.go') diff --git a/libpod/container_internal_unsupported.go b/libpod/container_internal_unsupported.go index 6fa19a778..05a587c59 100644 --- a/libpod/container_internal_unsupported.go +++ b/libpod/container_internal_unsupported.go @@ -40,3 +40,7 @@ func (c *Container) restore(ctx context.Context, options ContainerCheckpointOpti func (c *Container) copyOwnerAndPerms(source, dest string) error { return nil } + +func (c *Container) refreshCNI() error { + return define.ErrNotImplemented +} -- cgit v1.2.3-54-g00ecf