add debug logs if failed shards can not be resolved.

This commit is contained in:
Boaz Leskes 2014-04-16 14:45:54 +02:00
parent 840d1b4b8e
commit 099b9c6b06
1 changed files with 11 additions and 4 deletions

View File

@ -303,7 +303,7 @@ public class AllocationService extends AbstractComponent {
if (routingNodes.hasUnassignedPrimaries()) { if (routingNodes.hasUnassignedPrimaries()) {
for (MutableShardRouting shardEntry : routingNodes.unassigned()) { for (MutableShardRouting shardEntry : routingNodes.unassigned()) {
if (shardEntry.primary()) { if (shardEntry.primary()) {
for(MutableShardRouting routing : routingNodes.assignedShards(shardEntry)) { for (MutableShardRouting routing : routingNodes.assignedShards(shardEntry)) {
if (!routing.primary()) { if (!routing.primary()) {
changed = true; changed = true;
if (shardsToFail == null) { if (shardsToFail == null) {
@ -428,7 +428,7 @@ public class AllocationService extends AbstractComponent {
// first, we need to cancel the current node that is being initialized // first, we need to cancel the current node that is being initialized
RoutingNodes.RoutingNodeIterator initializingNode = routingNodes.routingNodeIter(failedShard.currentNodeId()); RoutingNodes.RoutingNodeIterator initializingNode = routingNodes.routingNodeIter(failedShard.currentNodeId());
if (initializingNode != null) { if (initializingNode != null) {
while(initializingNode.hasNext()) { while (initializingNode.hasNext()) {
MutableShardRouting shardRouting = initializingNode.next(); MutableShardRouting shardRouting = initializingNode.next();
if (shardRouting.equals(failedShard)) { if (shardRouting.equals(failedShard)) {
dirty = true; dirty = true;
@ -454,6 +454,8 @@ public class AllocationService extends AbstractComponent {
} }
} }
} }
} else {
logger.debug("failed shard {} not found in routingNodes, ignoring it", failedShard);
} }
return dirty; return dirty;
} else if (failedShard.state() == RELOCATING) { } else if (failedShard.state() == RELOCATING) {
@ -464,7 +466,7 @@ public class AllocationService extends AbstractComponent {
// and add it to the unassigned shards list... // and add it to the unassigned shards list...
RoutingNodes.RoutingNodeIterator relocatingFromNode = routingNodes.routingNodeIter(failedShard.currentNodeId()); RoutingNodes.RoutingNodeIterator relocatingFromNode = routingNodes.routingNodeIter(failedShard.currentNodeId());
if (relocatingFromNode != null) { if (relocatingFromNode != null) {
while(relocatingFromNode.hasNext()) { while (relocatingFromNode.hasNext()) {
MutableShardRouting shardRouting = relocatingFromNode.next(); MutableShardRouting shardRouting = relocatingFromNode.next();
if (shardRouting.equals(failedShard)) { if (shardRouting.equals(failedShard)) {
dirty = true; dirty = true;
@ -492,6 +494,8 @@ public class AllocationService extends AbstractComponent {
} }
} }
} }
} else {
logger.debug("failed shard {} not found in routingNodes, ignoring it", failedShard);
} }
return dirty; return dirty;
} else { } else {
@ -502,7 +506,7 @@ public class AllocationService extends AbstractComponent {
boolean dirty = false; boolean dirty = false;
RoutingNodes.RoutingNodeIterator node = routingNodes.routingNodeIter(failedShard.currentNodeId()); RoutingNodes.RoutingNodeIterator node = routingNodes.routingNodeIter(failedShard.currentNodeId());
if (node != null) { if (node != null) {
while(node.hasNext()) { while (node.hasNext()) {
MutableShardRouting shardRouting = node.next(); MutableShardRouting shardRouting = node.next();
if (shardRouting.equals(failedShard)) { if (shardRouting.equals(failedShard)) {
dirty = true; dirty = true;
@ -534,6 +538,9 @@ public class AllocationService extends AbstractComponent {
} }
} }
} }
if (!dirty) {
logger.debug("failed shard {} not found in routingNodes, ignoring it", failedShard);
}
return dirty; return dirty;
} }
} }