From f6536bf30eddf02c01524f54d8940758fc3a7c14 Mon Sep 17 00:00:00 2001 From: Crazykev Date: Tue, 11 Oct 2016 20:19:51 +0800 Subject: [PATCH] pod/container name should be released when create failed Signed-off-by: Crazykev --- server/container.go | 1 + server/sandbox.go | 9 +++++---- server/server.go | 4 ++-- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/server/container.go b/server/container.go index 8adc46fa..08ed4b06 100644 --- a/server/container.go +++ b/server/container.go @@ -93,6 +93,7 @@ func (s *Server) CreateContainer(ctx context.Context, req *pb.CreateContainerReq containerDir := filepath.Join(s.runtime.ContainerDir(), containerID) defer func() { if err != nil { + s.releaseContainerName(containerName) err1 := os.RemoveAll(containerDir) if err1 != nil { logrus.Warnf("Failed to cleanup container directory: %v") diff --git a/server/sandbox.go b/server/sandbox.go index 303dbbd9..18764b0c 100644 --- a/server/sandbox.go +++ b/server/sandbox.go @@ -104,18 +104,19 @@ func (s *Server) RunPodSandbox(ctx context.Context, req *pb.RunPodSandboxRequest return nil, fmt.Errorf("pod sandbox (%s) already exists", podSandboxDir) } - if err = os.MkdirAll(podSandboxDir, 0755); err != nil { - return nil, err - } - defer func() { if err != nil { + s.releasePodName(name) if err2 := os.RemoveAll(podSandboxDir); err2 != nil { logrus.Warnf("couldn't cleanup podSandboxDir %s: %v", podSandboxDir, err2) } } }() + if err = os.MkdirAll(podSandboxDir, 0755); err != nil { + return nil, err + } + // creates a spec Generator with the default spec. g := generate.New() diff --git a/server/server.go b/server/server.go index 19af7b4c..9433d038 100644 --- a/server/server.go +++ b/server/server.go @@ -192,10 +192,10 @@ func (s *Server) reserveContainerName(id, name string) (string, error) { if err == registrar.ErrNameReserved { id, err := s.ctrNameIndex.Get(name) if err != nil { - logrus.Warnf("name %s already reserved for %s", name, id) + logrus.Warnf("get reserved name %s failed", name) return "", err } - return "", fmt.Errorf("conflict, name %s already reserved", name) + return "", fmt.Errorf("conflict, name %s already reserved for %s", name, id) } return "", fmt.Errorf("error reserving name %s", name) }