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:
Boaz Leskes 2015-07-23 09:37:30 +02:00
parent e997342da4
commit 57cbce2824
1 changed files with 2 additions and 2 deletions

View File

@ -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++;
} }
} }