|
@ -2,15 +2,16 @@ package topology |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
"errors" |
|
|
"errors" |
|
|
|
|
|
"math/rand" |
|
|
|
|
|
"strings" |
|
|
|
|
|
"sync" |
|
|
|
|
|
"sync/atomic" |
|
|
|
|
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/glog" |
|
|
"github.com/seaweedfs/seaweedfs/weed/glog" |
|
|
"github.com/seaweedfs/seaweedfs/weed/stats" |
|
|
"github.com/seaweedfs/seaweedfs/weed/stats" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/erasure_coding" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/erasure_coding" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/needle" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/needle" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/types" |
|
|
"github.com/seaweedfs/seaweedfs/weed/storage/types" |
|
|
"math/rand" |
|
|
|
|
|
"strings" |
|
|
|
|
|
"sync" |
|
|
|
|
|
"sync/atomic" |
|
|
|
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
type NodeId string |
|
|
type NodeId string |
|
@ -73,7 +74,7 @@ func (n *NodeImpl) PickNodesByWeight(numberOfNodes int, option *VolumeGrowOption |
|
|
n.RUnlock() |
|
|
n.RUnlock() |
|
|
if len(candidates) < numberOfNodes { |
|
|
if len(candidates) < numberOfNodes { |
|
|
glog.V(0).Infoln(n.Id(), "failed to pick", numberOfNodes, "from ", len(candidates), "node candidates") |
|
|
glog.V(0).Infoln(n.Id(), "failed to pick", numberOfNodes, "from ", len(candidates), "node candidates") |
|
|
return nil, nil, errors.New("No enough data node found!") |
|
|
|
|
|
|
|
|
return nil, nil, errors.New("Not enough data nodes found!") |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//pick nodes randomly by weights, the node picked earlier has higher final weights
|
|
|
//pick nodes randomly by weights, the node picked earlier has higher final weights
|
|
|