Browse Source

handle possible race condition

pull/2427/head
Chris Lu 3 years ago
parent
commit
3c245c69d3
  1. 13
      weed/server/master_server_cluster.go

13
weed/server/master_server_cluster.go

@ -14,6 +14,7 @@ const (
type ClusterNode struct {
address pb.ServerAddress
version string
counter int
}
type Cluster struct {
@ -32,12 +33,14 @@ func (cluster *Cluster) AddClusterNode(nodeType string, address pb.ServerAddress
case "filer":
cluster.filersLock.Lock()
defer cluster.filersLock.Unlock()
if _, found := cluster.filers[address]; found {
if existingNode, found := cluster.filers[address]; found {
existingNode.counter++
return
}
cluster.filers[address] = &ClusterNode{
address: address,
version: version,
counter: 1,
}
case "master":
}
@ -48,10 +51,14 @@ func (cluster *Cluster) RemoveClusterNode(nodeType string, address pb.ServerAddr
case "filer":
cluster.filersLock.Lock()
defer cluster.filersLock.Unlock()
if _, found := cluster.filers[address]; !found {
if existingNode, found := cluster.filers[address]; !found {
return
}
} else {
existingNode.counter--
if existingNode.counter <= 0 {
delete(cluster.filers, address)
}
}
case "master":
}
}

Loading…
Cancel
Save