From d52195f68fd3083df9ab1c0392ef218024bf9aec Mon Sep 17 00:00:00 2001 From: Xie Yongji Date: Mon, 6 May 2019 15:29:23 +0800 Subject: [PATCH] mount: Add a proper rollback path to addStorages() We need a proper rollback to decrement the sandbox storage reference counter when addStorages() failed. Fixes: #549 Signed-off-by: Xie Yongji (cherry picked from commit c66349b6c91156fbf59027e6c57f6aa211f365d0) Signed-off-by: Ganesh Maharaj Mahalingam --- mount.go | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/mount.go b/mount.go index 7b74b1f258..1113965ebd 100644 --- a/mount.go +++ b/mount.go @@ -279,12 +279,28 @@ func mountStorage(storage pb.Storage) error { // associated operations such as waiting for the device to show up, and mount // it to a specific location, according to the type of handler chosen, and for // each storage. -func addStorages(ctx context.Context, storages []*pb.Storage, s *sandbox) ([]string, error) { +func addStorages(ctx context.Context, storages []*pb.Storage, s *sandbox) (mounts []string, err error) { span, ctx := trace(ctx, "mount", "addStorages") span.SetTag("sandbox", s.id) defer span.Finish() var mountList []string + var storageList []string + + defer func() { + if err != nil { + s.Lock() + for _, path := range storageList { + if err := s.unsetAndRemoveSandboxStorage(path); err != nil { + agentLog.WithFields(logrus.Fields{ + "error": err, + "path": path, + }).Error("failed to roll back addStorages") + } + } + s.Unlock() + } + }() for _, storage := range storages { if storage == nil { @@ -304,6 +320,10 @@ func addStorages(ctx context.Context, storages []*pb.Storage, s *sandbox) ([]str mountPoint, err := devHandler(*storage, s) handlerSpan.Finish() + if _, ok := s.storages[storage.MountPoint]; ok { + storageList = append([]string{storage.MountPoint}, storageList...) + } + if err != nil { return nil, err }