Allocation: ThrottlingAllocationDecider should not counting relocating shards
The ThrottlingAllocationDecider is responsible to limit the number of incoming/local recoveries on a node. It therefore shouldn't count shards marked as relocating which represent the source of the recovery. Closes #12409
This commit is contained in:
parent
e997342da4
commit
57cbce2824
|
@ -38,7 +38,7 @@ import org.elasticsearch.node.settings.NodeSettingsService;
|
||||||
* node. The default is <tt>4</tt></li>
|
* node. The default is <tt>4</tt></li>
|
||||||
* <p/>
|
* <p/>
|
||||||
* <li><tt>cluster.routing.allocation.node_concurrent_recoveries</tt> -
|
* <li><tt>cluster.routing.allocation.node_concurrent_recoveries</tt> -
|
||||||
* restricts the number of concurrent recovery operations on a single node. The
|
* restricts the number of total concurrent shards initializing on a single node. The
|
||||||
* default is <tt>2</tt></li>
|
* default is <tt>2</tt></li>
|
||||||
* </ul>
|
* </ul>
|
||||||
* <p/>
|
* <p/>
|
||||||
|
@ -106,7 +106,7 @@ public class ThrottlingAllocationDecider extends AllocationDecider {
|
||||||
public Decision canAllocate(RoutingNode node, RoutingAllocation allocation) {
|
public Decision canAllocate(RoutingNode node, RoutingAllocation allocation) {
|
||||||
int currentRecoveries = 0;
|
int currentRecoveries = 0;
|
||||||
for (ShardRouting shard : node) {
|
for (ShardRouting shard : node) {
|
||||||
if (shard.initializing() || shard.relocating()) {
|
if (shard.initializing()) {
|
||||||
currentRecoveries++;
|
currentRecoveries++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue