mirror of https://github.com/apache/lucene.git
SOLR-5580: NPE when creating a core with both explicit shard and coreNodeName.
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1553967 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
26e92f36ad
commit
c3f2a19022
|
@ -302,6 +302,9 @@ Bug Fixes
|
||||||
webcontainers / proxies. (Jakob Furrer, hossman, Shawn Heisey, Uwe Schindler,
|
webcontainers / proxies. (Jakob Furrer, hossman, Shawn Heisey, Uwe Schindler,
|
||||||
Mark Miller)
|
Mark Miller)
|
||||||
|
|
||||||
|
* SOLR-5580: NPE when creating a core with both explicit shard and coreNodeName.
|
||||||
|
(YouPeng Yang, Mark Miller)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -442,18 +442,10 @@ public class Overseer {
|
||||||
// if coreNodeName is null, auto assign one
|
// if coreNodeName is null, auto assign one
|
||||||
coreNodeName = Assign.assignNode(collection, state);
|
coreNodeName = Assign.assignNode(collection, state);
|
||||||
}
|
}
|
||||||
message.getProperties().put(ZkStateReader.CORE_NODE_NAME_PROP, coreNodeName);
|
message.getProperties().put(ZkStateReader.CORE_NODE_NAME_PROP,
|
||||||
} else {
|
coreNodeName);
|
||||||
//probably, this core was removed explicitly
|
|
||||||
if (sliceName !=null && collectionExists && !"true".equals(state.getCollection(collection).getStr("autoCreated"))) {
|
|
||||||
Slice slice = state.getSlice(collection, sliceName);
|
|
||||||
if (slice.getReplica(coreNodeName) == null) {
|
|
||||||
log.info("core_deleted . Just return");
|
|
||||||
return state;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// use the provided non null shardId
|
// use the provided non null shardId
|
||||||
if (sliceName == null) {
|
if (sliceName == null) {
|
||||||
//get shardId from ClusterState
|
//get shardId from ClusterState
|
||||||
|
|
|
@ -34,6 +34,7 @@ import java.util.concurrent.Future;
|
||||||
import java.util.concurrent.SynchronousQueue;
|
import java.util.concurrent.SynchronousQueue;
|
||||||
import java.util.concurrent.ThreadPoolExecutor;
|
import java.util.concurrent.ThreadPoolExecutor;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.lucene.util.LuceneTestCase.Slow;
|
import org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
|
@ -100,6 +101,8 @@ public class BasicDistributedZkTest extends AbstractFullDistribZkTestBase {
|
||||||
private String oneInstanceCollection = "oneInstanceCollection";
|
private String oneInstanceCollection = "oneInstanceCollection";
|
||||||
private String oneInstanceCollection2 = "oneInstanceCollection2";
|
private String oneInstanceCollection2 = "oneInstanceCollection2";
|
||||||
|
|
||||||
|
private AtomicInteger nodeCounter = new AtomicInteger();
|
||||||
|
|
||||||
ThreadPoolExecutor executor = new ThreadPoolExecutor(0,
|
ThreadPoolExecutor executor = new ThreadPoolExecutor(0,
|
||||||
Integer.MAX_VALUE, 5, TimeUnit.SECONDS, new SynchronousQueue<Runnable>(),
|
Integer.MAX_VALUE, 5, TimeUnit.SECONDS, new SynchronousQueue<Runnable>(),
|
||||||
new DefaultSolrThreadFactory("testExecutor"));
|
new DefaultSolrThreadFactory("testExecutor"));
|
||||||
|
@ -928,11 +931,16 @@ public class BasicDistributedZkTest extends AbstractFullDistribZkTestBase {
|
||||||
try {
|
try {
|
||||||
server = new HttpSolrServer(baseUrl);
|
server = new HttpSolrServer(baseUrl);
|
||||||
server.setConnectionTimeout(15000);
|
server.setConnectionTimeout(15000);
|
||||||
server.setSoTimeout(60000);
|
|
||||||
Create createCmd = new Create();
|
Create createCmd = new Create();
|
||||||
createCmd.setRoles("none");
|
createCmd.setRoles("none");
|
||||||
createCmd.setCoreName(collection + num);
|
createCmd.setCoreName(collection + num);
|
||||||
createCmd.setCollection(collection);
|
createCmd.setCollection(collection);
|
||||||
|
|
||||||
|
if (random().nextBoolean()) {
|
||||||
|
// sometimes we use an explicit core node name
|
||||||
|
createCmd.setCoreNodeName("anode" + nodeCounter.incrementAndGet());
|
||||||
|
}
|
||||||
|
|
||||||
if (shardId == null) {
|
if (shardId == null) {
|
||||||
createCmd.setNumShards(2);
|
createCmd.setNumShards(2);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue