浏览代码

Merge pull request #1161 from aboch/fx

IPAM allocator to not accept a datastore update if already present
Madhu Venugopal 9 年之前
父节点
当前提交
d29f63afe6
共有 1 个文件被更改,包括 5 次插入3 次删除
  1. 5 3
      libnetwork/ipam/allocator.go

+ 5 - 3
libnetwork/ipam/allocator.go

@@ -147,9 +147,11 @@ func (a *Allocator) initializeAddressSpace(as string, ds datastore.DataStore) er
 	}
 
 	a.Lock()
-	if _, ok := a.addrSpaces[as]; ok {
-		a.Unlock()
-		return types.ForbiddenErrorf("tried to add an axisting address space: %s", as)
+	if currAS, ok := a.addrSpaces[as]; ok {
+		if currAS.ds != nil {
+			a.Unlock()
+			return types.ForbiddenErrorf("a datastore is already configured for the address space %s", as)
+		}
 	}
 	a.addrSpaces[as] = &addrSpace{
 		subnets: map[SubnetKey]*PoolData{},