mirror of https://github.com/apache/lucene.git
SOLR-11041: MoveReplicaCmd do not specify ulog dir in case of HDFS
This commit is contained in:
parent
57f7493c1a
commit
ad7f2a787d
|
@ -330,6 +330,8 @@ Bug Fixes
|
||||||
|
|
||||||
* SOLR-11039: Next button in Solr admin UI for collection list pagination does not work. (janhoy)
|
* SOLR-11039: Next button in Solr admin UI for collection list pagination does not work. (janhoy)
|
||||||
|
|
||||||
|
* SOLR-11041: MoveReplicaCmd do not specify ulog dir in case of HDFS (Cao Manh Dat)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -139,6 +139,7 @@ public class AddReplicaCmd implements OverseerCollectionMessageHandler.Cmd {
|
||||||
String configName = zkStateReader.readConfigName(collection);
|
String configName = zkStateReader.readConfigName(collection);
|
||||||
String routeKey = message.getStr(ShardParams._ROUTE_);
|
String routeKey = message.getStr(ShardParams._ROUTE_);
|
||||||
String dataDir = message.getStr(CoreAdminParams.DATA_DIR);
|
String dataDir = message.getStr(CoreAdminParams.DATA_DIR);
|
||||||
|
String ulogDir = message.getStr(CoreAdminParams.ULOG_DIR);
|
||||||
String instanceDir = message.getStr(CoreAdminParams.INSTANCE_DIR);
|
String instanceDir = message.getStr(CoreAdminParams.INSTANCE_DIR);
|
||||||
|
|
||||||
params.set(CoreAdminParams.ACTION, CoreAdminParams.CoreAdminAction.CREATE.toString());
|
params.set(CoreAdminParams.ACTION, CoreAdminParams.CoreAdminAction.CREATE.toString());
|
||||||
|
@ -161,6 +162,9 @@ public class AddReplicaCmd implements OverseerCollectionMessageHandler.Cmd {
|
||||||
if (dataDir != null) {
|
if (dataDir != null) {
|
||||||
params.set(CoreAdminParams.DATA_DIR, dataDir);
|
params.set(CoreAdminParams.DATA_DIR, dataDir);
|
||||||
}
|
}
|
||||||
|
if (ulogDir != null) {
|
||||||
|
params.set(CoreAdminParams.ULOG_DIR, ulogDir);
|
||||||
|
}
|
||||||
if (instanceDir != null) {
|
if (instanceDir != null) {
|
||||||
params.set(CoreAdminParams.INSTANCE_DIR, instanceDir);
|
params.set(CoreAdminParams.INSTANCE_DIR, instanceDir);
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,7 @@ import org.apache.solr.common.cloud.ZkNodeProps;
|
||||||
import org.apache.solr.common.params.CoreAdminParams;
|
import org.apache.solr.common.params.CoreAdminParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.apache.solr.common.util.Utils;
|
import org.apache.solr.common.util.Utils;
|
||||||
|
import org.apache.solr.update.UpdateLog;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
@ -134,11 +135,13 @@ public class MoveReplicaCmd implements Cmd{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String ulogDir = replica.getStr(CoreAdminParams.ULOG_DIR);
|
||||||
ZkNodeProps addReplicasProps = new ZkNodeProps(
|
ZkNodeProps addReplicasProps = new ZkNodeProps(
|
||||||
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,
|
||||||
|
CoreAdminParams.ULOG_DIR, ulogDir.substring(0, ulogDir.lastIndexOf(UpdateLog.TLOG_NAME)),
|
||||||
CoreAdminParams.DATA_DIR, dataDir);
|
CoreAdminParams.DATA_DIR, dataDir);
|
||||||
if(async!=null) addReplicasProps.getProperties().put(ASYNC, async);
|
if(async!=null) addReplicasProps.getProperties().put(ASYNC, async);
|
||||||
NamedList addResult = new NamedList();
|
NamedList addResult = new NamedList();
|
||||||
|
|
|
@ -126,6 +126,7 @@ import static org.apache.solr.common.params.CoreAdminParams.DELETE_DATA_DIR;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.DELETE_INDEX;
|
import static org.apache.solr.common.params.CoreAdminParams.DELETE_INDEX;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.DELETE_INSTANCE_DIR;
|
import static org.apache.solr.common.params.CoreAdminParams.DELETE_INSTANCE_DIR;
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.INSTANCE_DIR;
|
import static org.apache.solr.common.params.CoreAdminParams.INSTANCE_DIR;
|
||||||
|
import static org.apache.solr.common.params.CoreAdminParams.ULOG_DIR;
|
||||||
import static org.apache.solr.common.params.ShardParams._ROUTE_;
|
import static org.apache.solr.common.params.ShardParams._ROUTE_;
|
||||||
import static org.apache.solr.common.util.StrUtils.formatString;
|
import static org.apache.solr.common.util.StrUtils.formatString;
|
||||||
|
|
||||||
|
@ -633,6 +634,7 @@ public class CollectionsHandler extends RequestHandlerBase implements Permission
|
||||||
CoreAdminParams.NAME,
|
CoreAdminParams.NAME,
|
||||||
INSTANCE_DIR,
|
INSTANCE_DIR,
|
||||||
DATA_DIR,
|
DATA_DIR,
|
||||||
|
ULOG_DIR,
|
||||||
REPLICA_TYPE);
|
REPLICA_TYPE);
|
||||||
return copyPropertiesWithPrefix(req.getParams(), props, COLL_PROP_PREFIX);
|
return copyPropertiesWithPrefix(req.getParams(), props, COLL_PROP_PREFIX);
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -16,14 +16,24 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.cloud;
|
package org.apache.solr.cloud;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
import com.carrotsearch.randomizedtesting.ThreadFilter;
|
import com.carrotsearch.randomizedtesting.ThreadFilter;
|
||||||
import com.carrotsearch.randomizedtesting.annotations.ThreadLeakFilters;
|
import com.carrotsearch.randomizedtesting.annotations.ThreadLeakFilters;
|
||||||
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
||||||
|
import org.apache.solr.client.solrj.SolrServerException;
|
||||||
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
||||||
|
import org.apache.solr.client.solrj.response.CollectionAdminResponse;
|
||||||
import org.apache.solr.cloud.hdfs.HdfsTestUtil;
|
import org.apache.solr.cloud.hdfs.HdfsTestUtil;
|
||||||
|
import org.apache.solr.common.cloud.ClusterStateUtil;
|
||||||
|
import org.apache.solr.common.cloud.DocCollection;
|
||||||
|
import org.apache.solr.common.cloud.Replica;
|
||||||
import org.apache.solr.common.cloud.ZkConfigManager;
|
import org.apache.solr.common.cloud.ZkConfigManager;
|
||||||
|
import org.apache.solr.common.cloud.ZkStateReader;
|
||||||
import org.apache.solr.util.BadHdfsThreadsFilter;
|
import org.apache.solr.util.BadHdfsThreadsFilter;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -54,6 +64,41 @@ public class MoveReplicaHDFSTest extends MoveReplicaTest {
|
||||||
dfsCluster = null;
|
dfsCluster = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDataDirAndUlogAreMaintained() throws IOException, SolrServerException {
|
||||||
|
String coll = "movereplicatest_coll2";
|
||||||
|
CollectionAdminRequest.createCollection(coll, "conf1", 1, 1)
|
||||||
|
.setCreateNodeSet("")
|
||||||
|
.process(cluster.getSolrClient());
|
||||||
|
String hdfsUri = HdfsTestUtil.getURI(dfsCluster);
|
||||||
|
String dataDir = hdfsUri + "/dummyFolder/dataDir";
|
||||||
|
String ulogDir = hdfsUri + "/dummyFolder2/ulogDir";
|
||||||
|
CollectionAdminResponse res = CollectionAdminRequest
|
||||||
|
.addReplicaToShard(coll, "shard1")
|
||||||
|
.setDataDir(dataDir)
|
||||||
|
.setUlogDir(ulogDir)
|
||||||
|
.setNode(cluster.getJettySolrRunner(0).getNodeName())
|
||||||
|
.process(cluster.getSolrClient());
|
||||||
|
|
||||||
|
ulogDir += "/tlog";
|
||||||
|
ZkStateReader zkStateReader = cluster.getSolrClient().getZkStateReader();
|
||||||
|
ClusterStateUtil.waitForAllActiveAndLiveReplicas(zkStateReader, 120000);
|
||||||
|
DocCollection docCollection = zkStateReader.getClusterState().getCollection(coll);
|
||||||
|
Replica replica = docCollection.getReplicas().iterator().next();
|
||||||
|
assertTrue(replica.getStr("ulogDir"), replica.getStr("ulogDir").equals(ulogDir) || replica.getStr("ulogDir").equals(ulogDir+'/'));
|
||||||
|
assertTrue(replica.getStr("dataDir"),replica.getStr("dataDir").equals(dataDir) || replica.getStr("dataDir").equals(dataDir+'/'));
|
||||||
|
|
||||||
|
new CollectionAdminRequest.MoveReplica(coll, replica.getName(), cluster.getJettySolrRunner(1).getNodeName())
|
||||||
|
.process(cluster.getSolrClient());
|
||||||
|
ClusterStateUtil.waitForAllActiveAndLiveReplicas(zkStateReader, 120000);
|
||||||
|
docCollection = zkStateReader.getClusterState().getCollection(coll);
|
||||||
|
assertEquals(1, docCollection.getSlice("shard1").getReplicas().size());
|
||||||
|
replica = docCollection.getReplicas().iterator().next();
|
||||||
|
assertEquals(replica.getNodeName(), cluster.getJettySolrRunner(1).getNodeName());
|
||||||
|
assertTrue(replica.getStr("ulogDir"), replica.getStr("ulogDir").equals(ulogDir) || replica.getStr("ulogDir").equals(ulogDir+'/'));
|
||||||
|
assertTrue(replica.getStr("dataDir"),replica.getStr("dataDir").equals(dataDir) || replica.getStr("dataDir").equals(dataDir+'/'));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public static class ForkJoinThreadsFilter implements ThreadFilter {
|
public static class ForkJoinThreadsFilter implements ThreadFilter {
|
||||||
|
|
||||||
|
|
|
@ -1364,6 +1364,7 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
||||||
protected String routeKey;
|
protected String routeKey;
|
||||||
protected String instanceDir;
|
protected String instanceDir;
|
||||||
protected String dataDir;
|
protected String dataDir;
|
||||||
|
protected String ulogDir;
|
||||||
protected Properties properties;
|
protected Properties properties;
|
||||||
protected Replica.Type type;
|
protected Replica.Type type;
|
||||||
|
|
||||||
|
@ -1408,6 +1409,10 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
||||||
return instanceDir;
|
return instanceDir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getUlogDir() {
|
||||||
|
return ulogDir;
|
||||||
|
}
|
||||||
|
|
||||||
public AddReplica setInstanceDir(String instanceDir) {
|
public AddReplica setInstanceDir(String instanceDir) {
|
||||||
this.instanceDir = instanceDir;
|
this.instanceDir = instanceDir;
|
||||||
return this;
|
return this;
|
||||||
|
@ -1432,6 +1437,11 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public AddReplica setUlogDir(String ulogDir) {
|
||||||
|
this.ulogDir = ulogDir;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SolrParams getParams() {
|
public SolrParams getParams() {
|
||||||
ModifiableSolrParams params = new ModifiableSolrParams(super.getParams());
|
ModifiableSolrParams params = new ModifiableSolrParams(super.getParams());
|
||||||
|
@ -1452,6 +1462,9 @@ public abstract class CollectionAdminRequest<T extends CollectionAdminResponse>
|
||||||
if (dataDir != null) {
|
if (dataDir != null) {
|
||||||
params.add("dataDir", dataDir);
|
params.add("dataDir", dataDir);
|
||||||
}
|
}
|
||||||
|
if (ulogDir != null) {
|
||||||
|
params.add("ulogDir", ulogDir);
|
||||||
|
}
|
||||||
if (coreName != null) {
|
if (coreName != null) {
|
||||||
params.add("name", coreName);
|
params.add("name", coreName);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue