mirror of https://github.com/apache/lucene.git
SOLR-13843: The MOVEREPLICA API ignores replica type and always adds 'nrt' replicas
This commit is contained in:
parent
63e9bcf5d1
commit
86a40c1cd5
|
@ -331,6 +331,8 @@ Bug Fixes
|
||||||
|
|
||||||
* SOLR-13835: HttpSolrCall produces incorrect extra AuditEvent on AuthorizationResponse.PROMPT (janhoy, hossman)
|
* SOLR-13835: HttpSolrCall produces incorrect extra AuditEvent on AuthorizationResponse.PROMPT (janhoy, hossman)
|
||||||
|
|
||||||
|
* SOLR-13843: The MOVEREPLICA API ignores replica type and always adds 'nrt' replicas (Amrit Sarkar via shalin)
|
||||||
|
|
||||||
Other Changes
|
Other Changes
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -218,7 +218,9 @@ public class MoveReplicaCmd implements OverseerCollectionMessageHandler.Cmd {
|
||||||
WAIT_FOR_FINAL_STATE, String.valueOf(waitForFinalState),
|
WAIT_FOR_FINAL_STATE, String.valueOf(waitForFinalState),
|
||||||
SKIP_CREATE_REPLICA_IN_CLUSTER_STATE, skipCreateReplicaInClusterState,
|
SKIP_CREATE_REPLICA_IN_CLUSTER_STATE, skipCreateReplicaInClusterState,
|
||||||
CoreAdminParams.ULOG_DIR, ulogDir.substring(0, ulogDir.lastIndexOf(UpdateLog.TLOG_NAME)),
|
CoreAdminParams.ULOG_DIR, ulogDir.substring(0, ulogDir.lastIndexOf(UpdateLog.TLOG_NAME)),
|
||||||
CoreAdminParams.DATA_DIR, dataDir);
|
CoreAdminParams.DATA_DIR, dataDir,
|
||||||
|
ZkStateReader.REPLICA_TYPE, replica.getType().name());
|
||||||
|
|
||||||
if(async!=null) addReplicasProps.getProperties().put(ASYNC, async);
|
if(async!=null) addReplicasProps.getProperties().put(ASYNC, async);
|
||||||
NamedList addResult = new NamedList();
|
NamedList addResult = new NamedList();
|
||||||
try {
|
try {
|
||||||
|
@ -272,7 +274,9 @@ public class MoveReplicaCmd implements OverseerCollectionMessageHandler.Cmd {
|
||||||
COLLECTION_PROP, coll.getName(),
|
COLLECTION_PROP, coll.getName(),
|
||||||
SHARD_ID_PROP, slice.getName(),
|
SHARD_ID_PROP, slice.getName(),
|
||||||
CoreAdminParams.NODE, targetNode,
|
CoreAdminParams.NODE, targetNode,
|
||||||
CoreAdminParams.NAME, newCoreName);
|
CoreAdminParams.NAME, newCoreName,
|
||||||
|
ZkStateReader.REPLICA_TYPE, replica.getType().name());
|
||||||
|
|
||||||
if (async != null) addReplicasProps.getProperties().put(ASYNC, async);
|
if (async != null) addReplicasProps.getProperties().put(ASYNC, async);
|
||||||
NamedList addResult = new NamedList();
|
NamedList addResult = new NamedList();
|
||||||
SolrCloseableLatch countDownLatch = new SolrCloseableLatch(1, ocmh);
|
SolrCloseableLatch countDownLatch = new SolrCloseableLatch(1, ocmh);
|
||||||
|
|
|
@ -55,6 +55,7 @@ import static org.apache.solr.common.params.CommonParams.NAME;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.COLLECTION;
|
import static org.apache.solr.common.params.CoreAdminParams.COLLECTION;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.CoreAdminAction.*;
|
import static org.apache.solr.common.params.CoreAdminParams.CoreAdminAction.*;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.REPLICA;
|
import static org.apache.solr.common.params.CoreAdminParams.REPLICA;
|
||||||
|
import static org.apache.solr.common.params.CoreAdminParams.REPLICA_TYPE;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.SHARD;
|
import static org.apache.solr.common.params.CoreAdminParams.SHARD;
|
||||||
import static org.apache.solr.handler.admin.CoreAdminHandler.COMPLETED;
|
import static org.apache.solr.handler.admin.CoreAdminHandler.COMPLETED;
|
||||||
import static org.apache.solr.handler.admin.CoreAdminHandler.CallInfo;
|
import static org.apache.solr.handler.admin.CoreAdminHandler.CallInfo;
|
||||||
|
@ -333,6 +334,7 @@ enum CoreAdminOperation implements CoreAdminOp {
|
||||||
cloudInfo.add(COLLECTION, core.getCoreDescriptor().getCloudDescriptor().getCollectionName());
|
cloudInfo.add(COLLECTION, core.getCoreDescriptor().getCloudDescriptor().getCollectionName());
|
||||||
cloudInfo.add(SHARD, core.getCoreDescriptor().getCloudDescriptor().getShardId());
|
cloudInfo.add(SHARD, core.getCoreDescriptor().getCloudDescriptor().getShardId());
|
||||||
cloudInfo.add(REPLICA, core.getCoreDescriptor().getCloudDescriptor().getCoreNodeName());
|
cloudInfo.add(REPLICA, core.getCoreDescriptor().getCloudDescriptor().getCoreNodeName());
|
||||||
|
cloudInfo.add(REPLICA_TYPE, core.getCoreDescriptor().getCloudDescriptor().getReplicaType().name());
|
||||||
info.add("cloud", cloudInfo);
|
info.add("cloud", cloudInfo);
|
||||||
}
|
}
|
||||||
if (isIndexInfoNeeded) {
|
if (isIndexInfoNeeded) {
|
||||||
|
|
|
@ -81,7 +81,7 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
fail("no overseer leader!");
|
fail("no overseer leader!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void afterTest() throws Exception {
|
public void afterTest() throws Exception {
|
||||||
try {
|
try {
|
||||||
|
@ -100,7 +100,9 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
CloudSolrClient cloudClient = cluster.getSolrClient();
|
CloudSolrClient cloudClient = cluster.getSolrClient();
|
||||||
|
|
||||||
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, REPLICATION);
|
// random create tlog or pull type replicas with nrt
|
||||||
|
boolean isTlog = random().nextBoolean();
|
||||||
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, 1, isTlog ? 1 : 0, !isTlog ? 1 : 0);
|
||||||
create.setMaxShardsPerNode(2);
|
create.setMaxShardsPerNode(2);
|
||||||
create.setAutoAddReplicas(false);
|
create.setAutoAddReplicas(false);
|
||||||
cloudClient.request(create);
|
cloudClient.request(create);
|
||||||
|
@ -126,8 +128,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int sourceNumCores = getNumOfCores(cloudClient, replica.getNodeName(), coll);
|
int sourceNumCores = getNumOfCores(cloudClient, replica.getNodeName(), coll, replica.getType().name());
|
||||||
int targetNumCores = getNumOfCores(cloudClient, targetNode, coll);
|
int targetNumCores = getNumOfCores(cloudClient, targetNode, coll, replica.getType().name());
|
||||||
|
|
||||||
CollectionAdminRequest.MoveReplica moveReplica = createMoveReplicaRequest(coll, replica, targetNode);
|
CollectionAdminRequest.MoveReplica moveReplica = createMoveReplicaRequest(coll, replica, targetNode);
|
||||||
moveReplica.setInPlaceMove(inPlaceMove);
|
moveReplica.setInPlaceMove(inPlaceMove);
|
||||||
|
@ -146,8 +148,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
Thread.sleep(500);
|
Thread.sleep(500);
|
||||||
}
|
}
|
||||||
assertTrue(success);
|
assertTrue(success);
|
||||||
assertEquals("should be one less core on the source node!", sourceNumCores - 1, getNumOfCores(cloudClient, replica.getNodeName(), coll));
|
assertEquals("should be one less core on the source node!", sourceNumCores - 1, getNumOfCores(cloudClient, replica.getNodeName(), coll, replica.getType().name()));
|
||||||
assertEquals("should be one more core on target node!", targetNumCores + 1, getNumOfCores(cloudClient, targetNode, coll));
|
assertEquals("should be one more core on target node!", targetNumCores + 1, getNumOfCores(cloudClient, targetNode, coll, replica.getType().name()));
|
||||||
// wait for recovery
|
// wait for recovery
|
||||||
boolean recovered = false;
|
boolean recovered = false;
|
||||||
for (int i = 0; i < 300; i++) {
|
for (int i = 0; i < 300; i++) {
|
||||||
|
@ -230,6 +232,7 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
assertEquals(100, cluster.getSolrClient().query(coll, new SolrQuery("*:*")).getResults().getNumFound());
|
assertEquals(100, cluster.getSolrClient().query(coll, new SolrQuery("*:*")).getResults().getNumFound());
|
||||||
}
|
}
|
||||||
|
|
||||||
//Commented out 5-Dec-2017
|
//Commented out 5-Dec-2017
|
||||||
// @AwaitsFix(bugUrl = "https://issues.apache.org/jira/browse/SOLR-11458")
|
// @AwaitsFix(bugUrl = "https://issues.apache.org/jira/browse/SOLR-11458")
|
||||||
@Test
|
@Test
|
||||||
|
@ -242,7 +245,9 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
CloudSolrClient cloudClient = cluster.getSolrClient();
|
CloudSolrClient cloudClient = cluster.getSolrClient();
|
||||||
|
|
||||||
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, REPLICATION);
|
// random create tlog or pull type replicas with nrt
|
||||||
|
boolean isTlog = random().nextBoolean();
|
||||||
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, 1, isTlog ? 1 : 0, !isTlog ? 1 : 0);
|
||||||
create.setAutoAddReplicas(false);
|
create.setAutoAddReplicas(false);
|
||||||
cloudClient.request(create);
|
cloudClient.request(create);
|
||||||
|
|
||||||
|
@ -315,28 +320,40 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkNumOfCores(CloudSolrClient cloudClient, String nodeName, String collectionName, int expectedCores) throws IOException, SolrServerException {
|
private void checkNumOfCores(CloudSolrClient cloudClient, String nodeName, String collectionName, int expectedCores) throws IOException, SolrServerException {
|
||||||
assertEquals(nodeName + " does not have expected number of cores",expectedCores, getNumOfCores(cloudClient, nodeName, collectionName));
|
assertEquals(nodeName + " does not have expected number of cores", expectedCores, getNumOfCores(cloudClient, nodeName, collectionName));
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getNumOfCores(CloudSolrClient cloudClient, String nodeName, String collectionName) throws IOException, SolrServerException {
|
private int getNumOfCores(CloudSolrClient cloudClient, String nodeName, String collectionName) throws IOException, SolrServerException {
|
||||||
|
return getNumOfCores(cloudClient, nodeName, collectionName, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getNumOfCores(CloudSolrClient cloudClient, String nodeName, String collectionName, String replicaType) throws IOException, SolrServerException {
|
||||||
try (HttpSolrClient coreclient = getHttpSolrClient(cloudClient.getZkStateReader().getBaseUrlForNodeName(nodeName))) {
|
try (HttpSolrClient coreclient = getHttpSolrClient(cloudClient.getZkStateReader().getBaseUrlForNodeName(nodeName))) {
|
||||||
CoreAdminResponse status = CoreAdminRequest.getStatus(null, coreclient);
|
CoreAdminResponse status = CoreAdminRequest.getStatus(null, coreclient);
|
||||||
if (status.getCoreStatus().size() == 0) {
|
if (status.getCoreStatus().size() == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
// filter size by collection name
|
if (collectionName == null && replicaType == null) {
|
||||||
if (collectionName == null) {
|
|
||||||
return status.getCoreStatus().size();
|
return status.getCoreStatus().size();
|
||||||
} else {
|
}
|
||||||
int size = 0;
|
// filter size by collection name
|
||||||
for (Map.Entry<String, NamedList<Object>> stringNamedListEntry : status.getCoreStatus()) {
|
int size = 0;
|
||||||
|
for (Map.Entry<String, NamedList<Object>> stringNamedListEntry : status.getCoreStatus()) {
|
||||||
|
if (collectionName != null) {
|
||||||
String coll = (String) stringNamedListEntry.getValue().findRecursive("cloud", "collection");
|
String coll = (String) stringNamedListEntry.getValue().findRecursive("cloud", "collection");
|
||||||
if (collectionName.equals(coll)) {
|
if (!collectionName.equals(coll)) {
|
||||||
size++;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return size;
|
if (replicaType != null) {
|
||||||
|
String type = (String) stringNamedListEntry.getValue().findRecursive("cloud", "replicaType");
|
||||||
|
if (!replicaType.equals(type)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
size++;
|
||||||
}
|
}
|
||||||
|
return size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue