SOLR-4933: Retry splitshard three times before giving up

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1498923 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Shalin Shekhar Mangar 2013-07-02 13:22:50 +00:00
parent 429bbe6950
commit c100f376f0
2 changed files with 41 additions and 40 deletions

View File

@ -360,13 +360,17 @@ public class OverseerCollectionProcessor implements Runnable, ClosableThread {
throw new SolrException(ErrorCode.BAD_REQUEST, "Sub-shard: " + subSlice + " exists in active state. Aborting split shard."); throw new SolrException(ErrorCode.BAD_REQUEST, "Sub-shard: " + subSlice + " exists in active state. Aborting split shard.");
} else if (Slice.CONSTRUCTION.equals(oSlice.getState())) { } else if (Slice.CONSTRUCTION.equals(oSlice.getState())) {
for (Replica replica : oSlice.getReplicas()) { for (Replica replica : oSlice.getReplicas()) {
String core = replica.getStr("core"); if (clusterState.liveNodesContain(replica.getNodeName())) {
log.info("Unloading core: " + core + " from node: " + replica.getNodeName()); String core = replica.getStr("core");
ModifiableSolrParams params = new ModifiableSolrParams(); log.info("Unloading core: " + core + " from node: " + replica.getNodeName());
params.set(CoreAdminParams.ACTION, CoreAdminAction.UNLOAD.toString()); ModifiableSolrParams params = new ModifiableSolrParams();
params.set(CoreAdminParams.CORE, core); params.set(CoreAdminParams.ACTION, CoreAdminAction.UNLOAD.toString());
params.set(CoreAdminParams.DELETE_INDEX, "true"); params.set(CoreAdminParams.CORE, core);
sendShardRequest(replica.getNodeName(), params); params.set(CoreAdminParams.DELETE_INDEX, "true");
sendShardRequest(replica.getNodeName(), params);
} else {
log.warn("Replica {} exists in shard {} but is not live and cannot be unloaded", replica, oSlice);
}
} }
} }
} }
@ -397,7 +401,12 @@ public class OverseerCollectionProcessor implements Runnable, ClosableThread {
//params.set(ZkStateReader.NUM_SHARDS_PROP, numSlices); todo: is it necessary, we're not creating collections? //params.set(ZkStateReader.NUM_SHARDS_PROP, numSlices); todo: is it necessary, we're not creating collections?
sendShardRequest(nodeName, params); sendShardRequest(nodeName, params);
}
collectShardResponses(results, true,
"SPLTSHARD failed to create subshard leaders");
for (String subShardName : subShardNames) {
// wait for parent leader to acknowledge the sub-shard core // wait for parent leader to acknowledge the sub-shard core
log.info("Asking parent leader to wait for: " + subShardName + " to be alive on: " + nodeName); log.info("Asking parent leader to wait for: " + subShardName + " to be alive on: " + nodeName);
String coreNodeName = waitForCoreNodeName(collection, zkStateReader.getZkClient().getBaseUrlForNodeName(nodeName), subShardName); String coreNodeName = waitForCoreNodeName(collection, zkStateReader.getZkClient().getBaseUrlForNodeName(nodeName), subShardName);
@ -412,7 +421,7 @@ public class OverseerCollectionProcessor implements Runnable, ClosableThread {
} }
collectShardResponses(results, true, collectShardResponses(results, true,
"SPLTSHARD failed to create subshard leaders or timed out waiting for them to come up"); "SPLTSHARD timed out waiting for subshard leaders to come up");
log.info("Successfully created all sub-shards for collection " log.info("Successfully created all sub-shards for collection "
+ collectionName + " parent shard: " + slice + " on: " + parentShardLeader); + collectionName + " parent shard: " + slice + " on: " + parentShardLeader);
@ -583,8 +592,13 @@ public class OverseerCollectionProcessor implements Runnable, ClosableThread {
srsp = shardHandler.takeCompletedOrError(); srsp = shardHandler.takeCompletedOrError();
if (srsp != null) { if (srsp != null) {
processResponse(results, srsp); processResponse(results, srsp);
if (abortOnError && srsp.getException() != null) { Throwable exception = srsp.getException();
throw new SolrException(ErrorCode.SERVER_ERROR, msgOnError, srsp.getException()); if (abortOnError && exception != null) {
// drain pending requests
while (srsp != null) {
srsp = shardHandler.takeCompletedOrError();
}
throw new SolrException(ErrorCode.SERVER_ERROR, msgOnError, exception);
} }
} }
} while (srsp != null); } while (srsp != null);

View File

@ -146,9 +146,22 @@ public class ShardSplitTest extends BasicDistributedZkTest {
indexThread.start(); indexThread.start();
try { try {
splitShard(SHARD1); for (int i = 0; i < 3; i++) {
log.info("Layout after split: \n"); try {
printLayout(); splitShard(SHARD1);
log.info("Layout after split: \n");
printLayout();
break;
} catch (HttpSolrServer.RemoteSolrException e) {
if (e.code() != 500) {
throw e;
}
log.error("SPLITSHARD failed. " + (i < 2 ? " Retring split" : ""), e);
if (i == 2) {
fail("SPLITSHARD was not successful even after three tries");
}
}
}
} finally { } finally {
try { try {
indexThread.join(); indexThread.join();
@ -158,33 +171,7 @@ public class ShardSplitTest extends BasicDistributedZkTest {
} }
commit(); commit();
checkDocCountsAndShardStates(docCounts, numReplicas);
try {
checkDocCountsAndShardStates(docCounts, numReplicas);
} catch (HttpSolrServer.RemoteSolrException e) {
if (e.code() != 500) {
throw e;
}
// if we get a 500 error, the split should be retried ... let's wait and see if it works...
Slice slice1_0 = null, slice1_1 = null;
int i = 0;
for (i = 0; i < 60; i++) {
ZkStateReader zkStateReader = cloudClient.getZkStateReader();
zkStateReader.updateClusterState(true);
clusterState = zkStateReader.getClusterState();
slice1_0 = clusterState.getSlice(AbstractDistribZkTestBase.DEFAULT_COLLECTION, "shard1_0");
slice1_1 = clusterState.getSlice(AbstractDistribZkTestBase.DEFAULT_COLLECTION, "shard1_1");
if (slice1_0 != null && slice1_1 != null) {
break;
}
Thread.sleep(500);
}
if (slice1_0 == null || slice1_1 == null) {
throw e;
}
}
// todo can't call waitForThingsToLevelOut because it looks for jettys of all shards // todo can't call waitForThingsToLevelOut because it looks for jettys of all shards
// and the new sub-shards don't have any. // and the new sub-shards don't have any.