|
@ -326,8 +326,10 @@ func balanceEcShardsWithinRacks(commandEnv *CommandEnv, allEcNodes []*EcNode, ra |
|
|
|
|
|
|
|
|
var possibleDestinationEcNodes []*EcNode |
|
|
var possibleDestinationEcNodes []*EcNode |
|
|
for _, n := range racks[RackId(rackId)].ecNodes { |
|
|
for _, n := range racks[RackId(rackId)].ecNodes { |
|
|
|
|
|
if _, found := n.info.DiskInfos[string(types.HardDriveType)]; found { |
|
|
possibleDestinationEcNodes = append(possibleDestinationEcNodes, n) |
|
|
possibleDestinationEcNodes = append(possibleDestinationEcNodes, n) |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
sourceEcNodes := rackEcNodesWithVid[rackId] |
|
|
sourceEcNodes := rackEcNodesWithVid[rackId] |
|
|
averageShardsPerEcNode := ceilDivide(rackToShardCount[rackId], len(possibleDestinationEcNodes)) |
|
|
averageShardsPerEcNode := ceilDivide(rackToShardCount[rackId], len(possibleDestinationEcNodes)) |
|
|
if err := doBalanceEcShardsWithinOneRack(commandEnv, averageShardsPerEcNode, collection, vid, sourceEcNodes, possibleDestinationEcNodes, applyBalancing); err != nil { |
|
|
if err := doBalanceEcShardsWithinOneRack(commandEnv, averageShardsPerEcNode, collection, vid, sourceEcNodes, possibleDestinationEcNodes, applyBalancing); err != nil { |
|
|