From b34c9a96839801495dc8b77542d7aa9c153df42b Mon Sep 17 00:00:00 2001
From: Yonik Seeley
Date: Mon, 10 Sep 2012 02:14:50 +0000
Subject: [PATCH] SOLR-3815: separate ZkNodeProps from Replica, change
properties from String values to Object values
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1382621 13f79535-47bb-0310-9956-ffa450edef68
---
.../carrot2/CarrotClusteringEngine.java | 2 +-
.../handler/dataimport/TestDIHEndToEnd.java | 2 +-
.../org/apache/solr/SolrLogFormatter.java | 10 +-
.../org/apache/solr/cloud/AssignShard.java | 2 +-
.../apache/solr/cloud/ElectionContext.java | 43 +++---
.../java/org/apache/solr/cloud/Overseer.java | 79 +++++------
.../cloud/OverseerCollectionProcessor.java | 29 ++--
.../apache/solr/cloud/RecoveryStrategy.java | 6 +-
.../org/apache/solr/cloud/SyncStrategy.java | 19 +--
.../org/apache/solr/cloud/ZkController.java | 13 +-
.../solr/handler/UpdateRequestHandler.java | 2 +-
.../solr/handler/admin/CoreAdminHandler.java | 6 +-
.../handler/admin/ShowFileRequestHandler.java | 2 +-
.../handler/component/HttpShardHandler.java | 3 +-
.../org/apache/solr/schema/FieldType.java | 2 +-
.../apache/solr/schema/RandomSortField.java | 2 +-
.../org/apache/solr/schema/SchemaField.java | 2 +-
.../solr/servlet/SolrDispatchFilter.java | 13 +-
.../processor/DistributedUpdateProcessor.java | 5 +-
.../FieldMutatingUpdateProcessorFactory.java | 2 +-
.../TestReversedWildcardFilterFactory.java | 2 +-
.../solr/cloud/BasicDistributedZk2Test.java | 5 +-
.../solr/cloud/BasicDistributedZkTest.java | 32 ++---
.../apache/solr/cloud/ClusterStateTest.java | 14 +-
.../solr/cloud/ClusterStateUpdateTest.java | 13 +-
.../cloud/LeaderElectionIntegrationTest.java | 2 +-
.../org/apache/solr/cloud/OverseerTest.java | 28 ++--
.../solr/cloud/TestHashPartitioner.java | 12 +-
.../test/org/apache/solr/cloud/ZkCLITest.java | 3 +-
.../apache/solr/cloud/ZkControllerTest.java | 2 +-
.../apache/solr/cloud/ZkNodePropsTest.java | 14 +-
.../apache/solr/search/QueryEqualityTest.java | 2 +-
.../solrj/impl/BinaryRequestWriter.java | 2 +-
.../client/solrj/impl/CloudSolrServer.java | 2 +-
.../client/solrj/response/QueryResponse.java | 2 +-
.../solr/common/cloud/ClusterState.java | 20 +--
.../solr/common/cloud/HashPartitioner.java | 40 +++++-
.../org/apache/solr/common/cloud/Replica.java | 38 +++++
.../org/apache/solr/common/cloud/Slice.java | 130 ++++++++++++++----
.../solr/common/cloud/ZkCoreNodeProps.java | 12 +-
.../apache/solr/common/cloud/ZkNodeProps.java | 75 +++++-----
.../solr/common/cloud/ZkStateReader.java | 4 +-
.../solr/cloud/AbstractDistribZkTestBase.java | 25 ++--
.../cloud/AbstractFullDistribZkTestBase.java | 39 +++---
.../apache/solr/cloud/AbstractZkTestCase.java | 2 +-
.../org/apache/solr/cloud/ChaosMonkey.java | 10 +-
46 files changed, 467 insertions(+), 307 deletions(-)
create mode 100644 solr/solrj/src/java/org/apache/solr/common/cloud/Replica.java
diff --git a/solr/contrib/clustering/src/java/org/apache/solr/handler/clustering/carrot2/CarrotClusteringEngine.java b/solr/contrib/clustering/src/java/org/apache/solr/handler/clustering/carrot2/CarrotClusteringEngine.java
index 52a85eb29b8..84665357f1c 100644
--- a/solr/contrib/clustering/src/java/org/apache/solr/handler/clustering/carrot2/CarrotClusteringEngine.java
+++ b/solr/contrib/clustering/src/java/org/apache/solr/handler/clustering/carrot2/CarrotClusteringEngine.java
@@ -194,7 +194,7 @@ public class CarrotClusteringEngine extends SearchClusteringEngine {
try {
configDir = "configDir=" + new File(resourceLoader.getConfigDir()).getAbsolutePath() + ", ";
} catch (Exception ignored) {
- // If we get the exception, the resource loader implementation
+ // If we get the exception, the resource loader implementation
// probably does not support getConfigDir(). Not a big problem.
}
diff --git a/solr/contrib/dataimporthandler/src/test/org/apache/solr/handler/dataimport/TestDIHEndToEnd.java b/solr/contrib/dataimporthandler/src/test/org/apache/solr/handler/dataimport/TestDIHEndToEnd.java
index 874fbf555f8..f8087c82a68 100644
--- a/solr/contrib/dataimporthandler/src/test/org/apache/solr/handler/dataimport/TestDIHEndToEnd.java
+++ b/solr/contrib/dataimporthandler/src/test/org/apache/solr/handler/dataimport/TestDIHEndToEnd.java
@@ -39,7 +39,7 @@ public class TestDIHEndToEnd extends AbstractDIHJdbcTestCase {
assertQ(req("COUNTRY_NAME:zealand"), "//*[@numFound='2']");
assertQ(req("COUNTRY_NAME:niue"), "//*[@numFound='3']");
- //It would be nice if there was a way to get it to run transformers before putting
+ //It would be nice if there was a way to get it to run transformers before putting
//data in the cache, then id=2 (person=Ethan, country=NU,NA,NE) could join...)
//assertQ(req("COUNTRY_NAME:Netherlands"), "//*[@numFound='3']");
diff --git a/solr/core/src/java/org/apache/solr/SolrLogFormatter.java b/solr/core/src/java/org/apache/solr/SolrLogFormatter.java
index 565d55b41b5..424c60d1fc8 100644
--- a/solr/core/src/java/org/apache/solr/SolrLogFormatter.java
+++ b/solr/core/src/java/org/apache/solr/SolrLogFormatter.java
@@ -19,7 +19,7 @@ package org.apache.solr;
import org.apache.solr.cloud.ZkController;
import org.apache.solr.common.SolrException;
-import org.apache.solr.common.cloud.ZkNodeProps;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.ZkStateReader;
import org.apache.solr.core.SolrCore;
import org.apache.solr.request.SolrQueryRequest;
@@ -99,7 +99,7 @@ public class SolrLogFormatter extends Formatter {
static int maxCoreNum;
String shortId;
String url;
- Map coreProps;
+ Map coreProps;
}
Map coreInfoMap = new WeakHashMap(); // TODO: use something that survives across a core reload?
@@ -200,7 +200,7 @@ sb.append("(group_name=").append(tg.getName()).append(")");
info.coreProps = getCoreProps(zkController, core);
}
- Map coreProps = getCoreProps(zkController, core);
+ Map coreProps = getCoreProps(zkController, core);
if(!coreProps.equals(info.coreProps)) {
info.coreProps = coreProps;
final String corePropsString = "coll:" + core.getCoreDescriptor().getCloudDescriptor().getCollectionName() + " core:" + core.getName() + " props:" + coreProps;
@@ -261,9 +261,9 @@ sb.append("(group_name=").append(tg.getName()).append(")");
return sb.toString();
}
- private Map getCoreProps(ZkController zkController, SolrCore core) {
+ private Map getCoreProps(ZkController zkController, SolrCore core) {
final String collection = core.getCoreDescriptor().getCloudDescriptor().getCollectionName();
- ZkNodeProps props = zkController.getClusterState().getShardProps(collection, ZkStateReader.getCoreNodeName(zkController.getNodeName(), core.getName()));
+ Replica props = zkController.getClusterState().getShardProps(collection, ZkStateReader.getCoreNodeName(zkController.getNodeName(), core.getName()));
if(props!=null) {
return props.getProperties();
}
diff --git a/solr/core/src/java/org/apache/solr/cloud/AssignShard.java b/solr/core/src/java/org/apache/solr/cloud/AssignShard.java
index 13dc8f4dc09..62dcaba516d 100644
--- a/solr/core/src/java/org/apache/solr/cloud/AssignShard.java
+++ b/solr/core/src/java/org/apache/solr/cloud/AssignShard.java
@@ -56,7 +56,7 @@ public class AssignShard {
// else figure out which shard needs more replicas
final Map map = new HashMap();
for (String shardId : shardIdNames) {
- int cnt = sliceMap.get(shardId).getShards().size();
+ int cnt = sliceMap.get(shardId).getReplicasMap().size();
map.put(shardId, cnt);
}
diff --git a/solr/core/src/java/org/apache/solr/cloud/ElectionContext.java b/solr/core/src/java/org/apache/solr/cloud/ElectionContext.java
index 82dbb4e16ce..43a8d10e79b 100644
--- a/solr/core/src/java/org/apache/solr/cloud/ElectionContext.java
+++ b/solr/core/src/java/org/apache/solr/cloud/ElectionContext.java
@@ -8,6 +8,7 @@ import java.util.Set;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
@@ -89,10 +90,10 @@ class ShardLeaderElectionContextBase extends ElectionContext {
zkClient.makePath(leaderPath, ZkStateReader.toJSON(leaderProps),
CreateMode.EPHEMERAL, true);
- ZkNodeProps m = new ZkNodeProps(Overseer.QUEUE_OPERATION, "leader",
+ ZkNodeProps m = ZkNodeProps.fromKeyVals(Overseer.QUEUE_OPERATION, "leader",
ZkStateReader.SHARD_ID_PROP, shardId, ZkStateReader.COLLECTION_PROP,
collection, ZkStateReader.BASE_URL_PROP, leaderProps.getProperties()
- .get(ZkStateReader.BASE_URL_PROP), ZkStateReader.CORE_NAME_PROP,
+ .get(ZkStateReader.BASE_URL_PROP), ZkStateReader.CORE_NAME_PROP,
leaderProps.getProperties().get(ZkStateReader.CORE_NAME_PROP),
ZkStateReader.STATE_PROP, ZkStateReader.ACTIVE);
Overseer.getInQueue(zkClient).offer(ZkStateReader.toJSON(m));
@@ -133,7 +134,7 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
InterruptedException, IOException {
log.info("Running the leader process. afterExpiration=" + afterExpiration);
- String coreName = leaderProps.get(ZkStateReader.CORE_NAME_PROP);
+ String coreName = leaderProps.getStr(ZkStateReader.CORE_NAME_PROP);
// clear the leader in clusterstate
ZkNodeProps m = new ZkNodeProps(Overseer.QUEUE_OPERATION, "leader",
@@ -244,11 +245,11 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
while (true && !isClosed) {
// wait for everyone to be up
if (slices != null) {
- Map shards = slices.getShards();
- Set> entrySet = shards.entrySet();
+ Map shards = slices.getReplicasMap();
+ Set> entrySet = shards.entrySet();
int found = 0;
tryAgain = false;
- for (Entry entry : entrySet) {
+ for (Entry entry : entrySet) {
ZkCoreNodeProps props = new ZkCoreNodeProps(entry.getValue());
if (props.getState().equals(ZkStateReader.ACTIVE)
&& zkController.getClusterState().liveNodesContain(
@@ -259,16 +260,16 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
// on startup and after connection timeout, wait for all known shards
if ((afterExpiration || !weAreReplacement)
- && found >= slices.getShards().size()) {
+ && found >= slices.getReplicasMap().size()) {
log.info("Enough replicas found to continue.");
break;
- } else if (!afterExpiration && found >= slices.getShards().size() - 1) {
+ } else if (!afterExpiration && found >= slices.getReplicasMap().size() - 1) {
// a previous leader went down - wait for one less than the total
// known shards
log.info("Enough replicas found to continue.");
break;
} else {
- log.info("Waiting until we see more replicas up: total=" + slices.getShards().size() + " found=" + found + " timeoutin=" + (timeoutAt - System.currentTimeMillis()));
+ log.info("Waiting until we see more replicas up: total=" + slices.getReplicasMap().size() + " found=" + found + " timeoutin=" + (timeoutAt - System.currentTimeMillis()));
}
if (System.currentTimeMillis() > timeoutAt) {
@@ -310,16 +311,16 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
ClusterState clusterState = zkController.getZkStateReader().getClusterState();
Map slices = clusterState.getSlices(this.collection);
Slice slice = slices.get(shardId);
- Map shards = slice.getShards();
+ Map shards = slice.getReplicasMap();
boolean foundSomeoneElseActive = false;
- for (Map.Entry shard : shards.entrySet()) {
- String state = shard.getValue().get(ZkStateReader.STATE_PROP);
+ for (Map.Entry shard : shards.entrySet()) {
+ String state = shard.getValue().getStr(ZkStateReader.STATE_PROP);
if (new ZkCoreNodeProps(shard.getValue()).getCoreUrl().equals(
new ZkCoreNodeProps(leaderProps).getCoreUrl())) {
if (state.equals(ZkStateReader.ACTIVE)
- && clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP))) {
+ && clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP))) {
// we are alive
log.info("I am Active and live, it's okay to be the leader.");
return true;
@@ -327,8 +328,8 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
}
if ((state.equals(ZkStateReader.ACTIVE))
- && clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP))
+ && clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP))
&& !new ZkCoreNodeProps(shard.getValue()).getCoreUrl().equals(
new ZkCoreNodeProps(leaderProps).getCoreUrl())) {
foundSomeoneElseActive = true;
@@ -354,15 +355,15 @@ final class ShardLeaderElectionContext extends ShardLeaderElectionContextBase {
ClusterState clusterState = zkController.getZkStateReader().getClusterState();
Map slices = clusterState.getSlices(this.collection);
Slice slice = slices.get(shardId);
- Map shards = slice.getShards();
+ Map shards = slice.getReplicasMap();
- for (Map.Entry shard : shards.entrySet()) {
- String state = shard.getValue().get(ZkStateReader.STATE_PROP);
+ for (Map.Entry shard : shards.entrySet()) {
+ String state = shard.getValue().getStr(ZkStateReader.STATE_PROP);
if ((state.equals(ZkStateReader.ACTIVE))
- && clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP))) {
+ && clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP))) {
return true;
}
}
diff --git a/solr/core/src/java/org/apache/solr/cloud/Overseer.java b/solr/core/src/java/org/apache/solr/cloud/Overseer.java
index b8b3654511a..a77fc2dcc3e 100644
--- a/solr/core/src/java/org/apache/solr/cloud/Overseer.java
+++ b/solr/core/src/java/org/apache/solr/cloud/Overseer.java
@@ -26,6 +26,7 @@ import java.util.Map.Entry;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.cloud.ClusterState;
import org.apache.solr.common.cloud.ClosableThread;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
@@ -87,7 +88,7 @@ public class Overseer {
while (head != null && amILeader()) {
final ZkNodeProps message = ZkNodeProps.load(head);
final String operation = message
- .get(QUEUE_OPERATION);
+ .getStr(QUEUE_OPERATION);
clusterState = processMessage(clusterState, message, operation);
zkClient.setData(ZkStateReader.CLUSTER_STATE,
ZkStateReader.toJSON(clusterState), true);
@@ -123,7 +124,7 @@ public class Overseer {
while (head != null) {
final ZkNodeProps message = ZkNodeProps.load(head);
- final String operation = message.get(QUEUE_OPERATION);
+ final String operation = message.getStr(QUEUE_OPERATION);
clusterState = processMessage(clusterState, message, operation);
workQueue.offer(head);
@@ -168,15 +169,15 @@ public class Overseer {
} else if (ZkStateReader.LEADER_PROP.equals(operation)) {
StringBuilder sb = new StringBuilder();
- String baseUrl = message.get(ZkStateReader.BASE_URL_PROP);
- String coreName = message.get(ZkStateReader.CORE_NAME_PROP);
+ String baseUrl = message.getStr(ZkStateReader.BASE_URL_PROP);
+ String coreName = message.getStr(ZkStateReader.CORE_NAME_PROP);
sb.append(baseUrl);
if (baseUrl != null && !baseUrl.endsWith("/")) sb.append("/");
sb.append(coreName == null ? "" : coreName);
if (!(sb.substring(sb.length() - 1).equals("/"))) sb.append("/");
clusterState = setShardLeader(clusterState,
- message.get(ZkStateReader.COLLECTION_PROP),
- message.get(ZkStateReader.SHARD_ID_PROP),
+ message.getStr(ZkStateReader.COLLECTION_PROP),
+ message.getStr(ZkStateReader.SHARD_ID_PROP),
sb.length() > 0 ? sb.toString() : null);
} else {
@@ -189,7 +190,7 @@ public class Overseer {
private boolean amILeader() {
try {
ZkNodeProps props = ZkNodeProps.load(zkClient.getData("/overseer_elect/leader", null, null, true));
- if(myId.equals(props.get("id"))) {
+ if(myId.equals(props.getStr("id"))) {
return true;
}
} catch (KeeperException e) {
@@ -204,9 +205,9 @@ public class Overseer {
* Try to assign core to the cluster.
*/
private ClusterState updateState(ClusterState state, final ZkNodeProps message) {
- final String collection = message.get(ZkStateReader.COLLECTION_PROP);
- final String zkCoreNodeName = message.get(ZkStateReader.NODE_NAME_PROP) + "_" + message.get(ZkStateReader.CORE_NAME_PROP);
- final Integer numShards = message.get(ZkStateReader.NUM_SHARDS_PROP)!=null?Integer.parseInt(message.get(ZkStateReader.NUM_SHARDS_PROP)):null;
+ final String collection = message.getStr(ZkStateReader.COLLECTION_PROP);
+ final String zkCoreNodeName = message.getStr(ZkStateReader.NODE_NAME_PROP) + "_" + message.getStr(ZkStateReader.CORE_NAME_PROP);
+ final Integer numShards = message.getStr(ZkStateReader.NUM_SHARDS_PROP)!=null?Integer.parseInt(message.getStr(ZkStateReader.NUM_SHARDS_PROP)):null;
//collection does not yet exist, create placeholders if num shards is specified
if (!state.getCollections().contains(collection)
@@ -215,9 +216,9 @@ public class Overseer {
}
// use the provided non null shardId
- String shardId = message.get(ZkStateReader.SHARD_ID_PROP);
+ String shardId = message.getStr(ZkStateReader.SHARD_ID_PROP);
if (shardId == null) {
- String nodeName = message.get(ZkStateReader.NODE_NAME_PROP);
+ String nodeName = message.getStr(ZkStateReader.NODE_NAME_PROP);
//get shardId from ClusterState
shardId = getAssignedId(state, nodeName, message);
}
@@ -226,22 +227,22 @@ public class Overseer {
shardId = AssignShard.assignShard(collection, state, numShards);
}
- Map props = new HashMap();
- Map coreProps = new HashMap(message.getProperties().size());
+ Map props = new HashMap();
+ Map coreProps = new HashMap(message.getProperties().size());
coreProps.putAll(message.getProperties());
// we don't put num_shards in the clusterstate
coreProps.remove(ZkStateReader.NUM_SHARDS_PROP);
coreProps.remove(QUEUE_OPERATION);
- for (Entry entry : coreProps.entrySet()) {
+ for (Entry entry : coreProps.entrySet()) {
props.put(entry.getKey(), entry.getValue());
}
- ZkNodeProps zkProps = new ZkNodeProps(props);
+ Replica zkProps = new Replica(zkCoreNodeName, props);
Slice slice = state.getSlice(collection, shardId);
- Map shardProps;
+ Map shardProps;
if (slice == null) {
- shardProps = new HashMap();
+ shardProps = new HashMap();
} else {
- shardProps = state.getSlice(collection, shardId).getShardsCopy();
+ shardProps = state.getSlice(collection, shardId).getReplicasCopy();
}
shardProps.put(zkCoreNodeName, zkProps);
@@ -268,11 +269,11 @@ public class Overseer {
*/
private String getAssignedId(final ClusterState state, final String nodeName,
final ZkNodeProps coreState) {
- final String key = coreState.get(ZkStateReader.NODE_NAME_PROP) + "_" + coreState.get(ZkStateReader.CORE_NAME_PROP);
- Map slices = state.getSlices(coreState.get(ZkStateReader.COLLECTION_PROP));
+ final String key = coreState.getStr(ZkStateReader.NODE_NAME_PROP) + "_" + coreState.getStr(ZkStateReader.CORE_NAME_PROP);
+ Map slices = state.getSlices(coreState.getStr(ZkStateReader.COLLECTION_PROP));
if (slices != null) {
for (Slice slice : slices.values()) {
- if (slice.getShards().get(key) != null) {
+ if (slice.getReplicasMap().get(key) != null) {
return slice.getName();
}
}
@@ -293,16 +294,16 @@ public class Overseer {
if (!slices.containsKey(slice.getName())) {
slices.put(slice.getName(), slice);
} else {
- final Map shards = new LinkedHashMap();
+ final Map shards = new LinkedHashMap();
final Slice existingSlice = slices.get(slice.getName());
- shards.putAll(existingSlice.getShards());
+ shards.putAll(existingSlice.getReplicasMap());
//XXX preserve existing leader
- for(Entry edit: slice.getShards().entrySet()) {
- if(existingSlice.getShards().get(edit.getKey())!=null && existingSlice.getShards().get(edit.getKey()).containsKey(ZkStateReader.LEADER_PROP)) {
- HashMap newProps = new HashMap();
+ for(Entry edit: slice.getReplicasMap().entrySet()) {
+ if(existingSlice.getReplicasMap().get(edit.getKey())!=null && existingSlice.getReplicasMap().get(edit.getKey()).containsKey(ZkStateReader.LEADER_PROP)) {
+ HashMap newProps = new HashMap();
newProps.putAll(edit.getValue().getProperties());
- newProps.put(ZkStateReader.LEADER_PROP, existingSlice.getShards().get(edit.getKey()).get(ZkStateReader.LEADER_PROP));
- shards.put(edit.getKey(), new ZkNodeProps(newProps));
+ newProps.put(ZkStateReader.LEADER_PROP, existingSlice.getReplicasMap().get(edit.getKey()).getStr(ZkStateReader.LEADER_PROP));
+ shards.put(edit.getKey(), new Replica(edit.getKey(), newProps));
} else {
shards.put(edit.getKey(), edit.getValue());
}
@@ -329,9 +330,9 @@ public class Overseer {
log.error("Could not mark leader for non existing slice:" + sliceName);
return state;
} else {
- final Map newShards = new LinkedHashMap();
- for(Entry shard: slices.get(sliceName).getShards().entrySet()) {
- Map newShardProps = new LinkedHashMap();
+ final Map newShards = new LinkedHashMap();
+ for(Entry shard: slices.get(sliceName).getReplicasMap().entrySet()) {
+ Map newShardProps = new LinkedHashMap();
newShardProps.putAll(shard.getValue().getProperties());
newShardProps.remove(ZkStateReader.LEADER_PROP); //clean any previously existed flag
@@ -340,7 +341,7 @@ public class Overseer {
if(leaderUrl!=null && leaderUrl.equals(zkCoreNodeProps.getCoreUrl())) {
newShardProps.put(ZkStateReader.LEADER_PROP,"true");
}
- newShards.put(shard.getKey(), new ZkNodeProps(newShardProps));
+ newShards.put(shard.getKey(), new Replica(shard.getKey(), newShardProps));
}
Slice slice = new Slice(sliceName, newShards);
slices.put(sliceName, slice);
@@ -353,8 +354,8 @@ public class Overseer {
*/
private ClusterState removeCore(final ClusterState clusterState, ZkNodeProps message) {
- final String coreNodeName = message.get(ZkStateReader.NODE_NAME_PROP) + "_" + message.get(ZkStateReader.CORE_NAME_PROP);
- final String collection = message.get(ZkStateReader.COLLECTION_PROP);
+ final String coreNodeName = message.getStr(ZkStateReader.NODE_NAME_PROP) + "_" + message.getStr(ZkStateReader.CORE_NAME_PROP);
+ final String collection = message.getStr(ZkStateReader.COLLECTION_PROP);
final LinkedHashMap> newStates = new LinkedHashMap>();
for(String collectionName: clusterState.getCollections()) {
@@ -362,9 +363,9 @@ public class Overseer {
Map slices = clusterState.getSlices(collection);
LinkedHashMap newSlices = new LinkedHashMap();
for(Slice slice: slices.values()) {
- if(slice.getShards().containsKey(coreNodeName)) {
- LinkedHashMap newShards = new LinkedHashMap();
- newShards.putAll(slice.getShards());
+ if(slice.getReplicasMap().containsKey(coreNodeName)) {
+ LinkedHashMap newShards = new LinkedHashMap();
+ newShards.putAll(slice.getReplicasMap());
newShards.remove(coreNodeName);
Slice newSlice = new Slice(slice.getName(), newShards);
@@ -376,7 +377,7 @@ public class Overseer {
}
int cnt = 0;
for (Slice slice : newSlices.values()) {
- cnt+=slice.getShards().size();
+ cnt+=slice.getReplicasMap().size();
}
// TODO: if no nodes are left after this unload
// remove from zk - do we have a race where Overseer
diff --git a/solr/core/src/java/org/apache/solr/cloud/OverseerCollectionProcessor.java b/solr/core/src/java/org/apache/solr/cloud/OverseerCollectionProcessor.java
index d4cacf1aef3..aa1f9f19332 100644
--- a/solr/core/src/java/org/apache/solr/cloud/OverseerCollectionProcessor.java
+++ b/solr/core/src/java/org/apache/solr/cloud/OverseerCollectionProcessor.java
@@ -26,6 +26,7 @@ import java.util.Set;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkNodeProps;
import org.apache.solr.common.cloud.ZkStateReader;
@@ -84,13 +85,13 @@ public class OverseerCollectionProcessor implements Runnable {
//if (head != null) { // should not happen since we block above
final ZkNodeProps message = ZkNodeProps.load(head);
- final String operation = message.get(QUEUE_OPERATION);
+ final String operation = message.getStr(QUEUE_OPERATION);
boolean success = processMessage(message, operation);
if (!success) {
// TODO: what to do on failure / partial failure
// if we fail, do we clean up then ?
- SolrException.log(log, "Collection creation of " + message.get("name") + " failed");
+ SolrException.log(log, "Collection creation of " + message.getStr("name") + " failed");
}
//}
workQueue.remove();
@@ -118,7 +119,7 @@ public class OverseerCollectionProcessor implements Runnable {
try {
ZkNodeProps props = ZkNodeProps.load(zkStateReader.getZkClient().getData(
"/overseer_elect/leader", null, null, true));
- if (myId.equals(props.get("id"))) {
+ if (myId.equals(props.getStr("id"))) {
return true;
}
} catch (KeeperException e) {
@@ -152,7 +153,7 @@ public class OverseerCollectionProcessor implements Runnable {
// look at the replication factor and see if it matches reality
// if it does not, find best nodes to create more cores
- String numReplicasString = message.get("numReplicas");
+ String numReplicasString = message.getStr("numReplicas");
int numReplicas;
try {
numReplicas = numReplicasString == null ? 0 : Integer.parseInt(numReplicasString);
@@ -160,7 +161,7 @@ public class OverseerCollectionProcessor implements Runnable {
SolrException.log(log, "Could not parse numReplicas", ex);
return false;
}
- String numShardsString = message.get("numShards");
+ String numShardsString = message.getStr("numShards");
int numShards;
try {
numShards = numShardsString == null ? 0 : Integer.parseInt(numShardsString);
@@ -169,8 +170,8 @@ public class OverseerCollectionProcessor implements Runnable {
return false;
}
- String name = message.get("name");
- String configName = message.get("collection.configName");
+ String name = message.getStr("name");
+ String configName = message.getStr("collection.configName");
// we need to look at every node and see how many cores it serves
// add our new cores to existing nodes serving the least number of cores
@@ -237,7 +238,7 @@ public class OverseerCollectionProcessor implements Runnable {
private boolean collectionCmd(ClusterState clusterState, ZkNodeProps message, ModifiableSolrParams params) {
log.info("Executing Collection Cmd : " + params);
- String name = message.get("name");
+ String name = message.getStr("name");
Map slices = clusterState.getCollectionStates().get(name);
@@ -247,14 +248,14 @@ public class OverseerCollectionProcessor implements Runnable {
for (Map.Entry entry : slices.entrySet()) {
Slice slice = entry.getValue();
- Map shards = slice.getShards();
- Set> shardEntries = shards.entrySet();
- for (Map.Entry shardEntry : shardEntries) {
+ Map shards = slice.getReplicasMap();
+ Set> shardEntries = shards.entrySet();
+ for (Map.Entry shardEntry : shardEntries) {
final ZkNodeProps node = shardEntry.getValue();
- if (clusterState.liveNodesContain(node.get(ZkStateReader.NODE_NAME_PROP))) {
- params.set(CoreAdminParams.CORE, node.get(ZkStateReader.CORE_NAME_PROP));
+ if (clusterState.liveNodesContain(node.getStr(ZkStateReader.NODE_NAME_PROP))) {
+ params.set(CoreAdminParams.CORE, node.getStr(ZkStateReader.CORE_NAME_PROP));
- String replica = node.get(ZkStateReader.BASE_URL_PROP);
+ String replica = node.getStr(ZkStateReader.BASE_URL_PROP);
ShardRequest sreq = new ShardRequest();
// yes, they must use same admin handler path everywhere...
params.set("qt", adminPath);
diff --git a/solr/core/src/java/org/apache/solr/cloud/RecoveryStrategy.java b/solr/core/src/java/org/apache/solr/cloud/RecoveryStrategy.java
index 737c8d92783..02c777fbbaa 100644
--- a/solr/core/src/java/org/apache/solr/cloud/RecoveryStrategy.java
+++ b/solr/core/src/java/org/apache/solr/cloud/RecoveryStrategy.java
@@ -119,7 +119,7 @@ public class RecoveryStrategy extends Thread implements ClosableThread {
private void replicate(String nodeName, SolrCore core, ZkNodeProps leaderprops, String baseUrl)
throws SolrServerException, IOException {
- String leaderBaseUrl = leaderprops.get(ZkStateReader.BASE_URL_PROP);
+ String leaderBaseUrl = leaderprops.getStr(ZkStateReader.BASE_URL_PROP);
ZkCoreNodeProps leaderCNodeProps = new ZkCoreNodeProps(leaderprops);
String leaderUrl = leaderCNodeProps.getCoreUrl();
@@ -318,8 +318,8 @@ public class RecoveryStrategy extends Thread implements ClosableThread {
ZkNodeProps leaderprops = zkStateReader.getLeaderProps(
cloudDesc.getCollectionName(), cloudDesc.getShardId());
- String leaderBaseUrl = leaderprops.get(ZkStateReader.BASE_URL_PROP);
- String leaderCoreName = leaderprops.get(ZkStateReader.CORE_NAME_PROP);
+ String leaderBaseUrl = leaderprops.getStr(ZkStateReader.BASE_URL_PROP);
+ String leaderCoreName = leaderprops.getStr(ZkStateReader.CORE_NAME_PROP);
String leaderUrl = ZkCoreNodeProps.getCoreUrl(leaderBaseUrl, leaderCoreName);
diff --git a/solr/core/src/java/org/apache/solr/cloud/SyncStrategy.java b/solr/core/src/java/org/apache/solr/cloud/SyncStrategy.java
index 36ce890c064..694b118b381 100644
--- a/solr/core/src/java/org/apache/solr/cloud/SyncStrategy.java
+++ b/solr/core/src/java/org/apache/solr/cloud/SyncStrategy.java
@@ -29,6 +29,7 @@ import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.client.solrj.request.CoreAdminRequest.RequestRecovery;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -136,9 +137,9 @@ public class SyncStrategy {
ClusterState clusterState = zkController.getZkStateReader().getClusterState();
Map slices = clusterState.getSlices(collection);
Slice slice = slices.get(shardId);
- Map shards = slice.getShards();
- for (Map.Entry shard : shards.entrySet()) {
- String state = shard.getValue().get(ZkStateReader.STATE_PROP);
+ Map shards = slice.getReplicasMap();
+ for (Map.Entry shard : shards.entrySet()) {
+ String state = shard.getValue().getStr(ZkStateReader.STATE_PROP);
// System.out.println("state:"
// + state
// + shard.getValue().get(ZkStateReader.NODE_NAME_PROP)
@@ -146,8 +147,8 @@ public class SyncStrategy {
// + clusterState.liveNodesContain(shard.getValue().get(
// ZkStateReader.NODE_NAME_PROP)));
if ((state.equals(ZkStateReader.ACTIVE))
- && clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP))
+ && clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP))
&& !new ZkCoreNodeProps(shard.getValue()).getCoreUrl().equals(
new ZkCoreNodeProps(leaderProps).getCoreUrl())) {
return true;
@@ -161,8 +162,8 @@ public class SyncStrategy {
ZkNodeProps props, String collection, String shardId) {
List nodes = zkController.getZkStateReader()
.getReplicaProps(collection, shardId,
- props.get(ZkStateReader.NODE_NAME_PROP),
- props.get(ZkStateReader.CORE_NAME_PROP), ZkStateReader.ACTIVE); // TODO:
+ props.getStr(ZkStateReader.NODE_NAME_PROP),
+ props.getStr(ZkStateReader.CORE_NAME_PROP), ZkStateReader.ACTIVE); // TODO:
// TODO should there be a state filter?
if (nodes == null) {
@@ -191,8 +192,8 @@ public class SyncStrategy {
List nodes = zkController
.getZkStateReader()
.getReplicaProps(collection, shardId,
- leaderProps.get(ZkStateReader.NODE_NAME_PROP),
- leaderProps.get(ZkStateReader.CORE_NAME_PROP), ZkStateReader.ACTIVE);
+ leaderProps.getStr(ZkStateReader.NODE_NAME_PROP),
+ leaderProps.getStr(ZkStateReader.CORE_NAME_PROP), ZkStateReader.ACTIVE);
if (nodes == null) {
log.info(ZkCoreNodeProps.getCoreUrl(leaderProps) + " has no replicas");
return;
diff --git a/solr/core/src/java/org/apache/solr/cloud/ZkController.java b/solr/core/src/java/org/apache/solr/cloud/ZkController.java
index 6b3e3567748..373e66024fb 100644
--- a/solr/core/src/java/org/apache/solr/cloud/ZkController.java
+++ b/solr/core/src/java/org/apache/solr/cloud/ZkController.java
@@ -41,7 +41,6 @@ import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.cloud.ClusterState;
import org.apache.solr.common.cloud.OnReconnect;
import org.apache.solr.common.cloud.SolrZkClient;
-import org.apache.solr.common.cloud.ZkClientConnectionStrategy;
import org.apache.solr.common.cloud.ZkCmdExecutor;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -492,7 +491,7 @@ public final class ZkController {
if(data != null) {
ZkNodeProps props = ZkNodeProps.load(data);
- configName = props.get(CONFIGNAME_PROP);
+ configName = props.getStr(CONFIGNAME_PROP);
}
if (configName != null && !zkClient.exists(CONFIGS_ZKNODE + "/" + configName, true)) {
@@ -539,7 +538,7 @@ public final class ZkController {
String shardId = cloudDesc.getShardId();
- Map props = new HashMap();
+ Map props = new HashMap();
// we only put a subset of props into the leader node
props.put(ZkStateReader.BASE_URL_PROP, baseUrl);
props.put(ZkStateReader.CORE_NAME_PROP, coreName);
@@ -695,7 +694,7 @@ public final class ZkController {
String shardId = cd.getCloudDescriptor().getShardId();
- Map props = new HashMap();
+ Map props = new HashMap();
// we only put a subset of props into the leader node
props.put(ZkStateReader.BASE_URL_PROP, getBaseUrl());
props.put(ZkStateReader.CORE_NAME_PROP, cd.getName());
@@ -872,7 +871,7 @@ public final class ZkController {
SolrParams params = cd.getParams();
try {
- Map collectionProps = new HashMap();
+ Map collectionProps = new HashMap();
// TODO: if collection.configName isn't set, and there isn't already a conf in zk, just use that?
String defaultConfigName = System.getProperty(COLLECTION_PARAM_PREFIX+CONFIGNAME_PROP, collection);
@@ -937,7 +936,7 @@ public final class ZkController {
private void getConfName(String collection, String collectionPath,
- Map collectionProps) throws KeeperException,
+ Map collectionProps) throws KeeperException,
InterruptedException {
// check for configName
log.info("Looking for collection configName");
@@ -1168,7 +1167,7 @@ public final class ZkController {
ZkNodeProps props = null;
if(data != null) {
props = ZkNodeProps.load(data);
- Map newProps = new HashMap();
+ Map newProps = new HashMap();
newProps.putAll(props.getProperties());
newProps.put(CONFIGNAME_PROP, confSetName);
props = new ZkNodeProps(newProps);
diff --git a/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java b/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java
index 473c1547714..3d136ebb28d 100644
--- a/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java
+++ b/solr/core/src/java/org/apache/solr/handler/UpdateRequestHandler.java
@@ -74,7 +74,7 @@ public class UpdateRequestHandler extends ContentStreamHandlerBase {
if(type == null) {
type = stream.getContentType();
}
- if( type == null ) { // Normal requests will not get here.
+ if( type == null ) { // Normal requests will not get here.
throw new SolrException(ErrorCode.BAD_REQUEST, "Missing ContentType");
}
int idx = type.indexOf(';');
diff --git a/solr/core/src/java/org/apache/solr/handler/admin/CoreAdminHandler.java b/solr/core/src/java/org/apache/solr/handler/admin/CoreAdminHandler.java
index 1c299a1e301..999f9957da3 100644
--- a/solr/core/src/java/org/apache/solr/handler/admin/CoreAdminHandler.java
+++ b/solr/core/src/java/org/apache/solr/handler/admin/CoreAdminHandler.java
@@ -851,7 +851,7 @@ public class CoreAdminHandler extends RequestHandlerBase {
if (core != null) {
SyncStrategy syncStrategy = new SyncStrategy();
- Map props = new HashMap();
+ Map props = new HashMap();
props.put(ZkStateReader.BASE_URL_PROP, zkController.getBaseUrl());
props.put(ZkStateReader.CORE_NAME_PROP, cname);
props.put(ZkStateReader.NODE_NAME_PROP, zkController.getNodeName());
@@ -934,9 +934,9 @@ public class CoreAdminHandler extends RequestHandlerBase {
Slice slice = clusterState.getSlice(collection,
cloudDescriptor.getShardId());
if (slice != null) {
- ZkNodeProps nodeProps = slice.getShards().get(coreNodeName);
+ ZkNodeProps nodeProps = slice.getReplicasMap().get(coreNodeName);
if (nodeProps != null) {
- state = nodeProps.get(ZkStateReader.STATE_PROP);
+ state = nodeProps.getStr(ZkStateReader.STATE_PROP);
live = clusterState.liveNodesContain(nodeName);
if (nodeProps != null && state.equals(waitForState)) {
if (checkLive == null) {
diff --git a/solr/core/src/java/org/apache/solr/handler/admin/ShowFileRequestHandler.java b/solr/core/src/java/org/apache/solr/handler/admin/ShowFileRequestHandler.java
index 5e07218a76a..34c42c77bf2 100644
--- a/solr/core/src/java/org/apache/solr/handler/admin/ShowFileRequestHandler.java
+++ b/solr/core/src/java/org/apache/solr/handler/admin/ShowFileRequestHandler.java
@@ -70,7 +70,7 @@ import java.util.Set;
* the registered invariant param for wt.
*
* If you want to override the contentType header returned for a given file, you can
- * set it directly using: {@link #USE_CONTENT_TYPE}. For example, to get a plain text
+ * set it directly using: {@link #USE_CONTENT_TYPE}. For example, to get a plain text
* version of schema.xml, try:
*
* http://localhost:8983/solr/admin/file?file=schema.xml&contentType=text/plain
diff --git a/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandler.java b/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandler.java
index e38abe8bc76..2fb6efb7e46 100644
--- a/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandler.java
+++ b/solr/core/src/java/org/apache/solr/handler/component/HttpShardHandler.java
@@ -42,6 +42,7 @@ import org.apache.solr.cloud.ZkController;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -350,7 +351,7 @@ public class HttpShardHandler extends ShardHandler {
// throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "no such shard: " + sliceName);
}
- Map sliceShards = slice.getShards();
+ Map sliceShards = slice.getReplicasMap();
// For now, recreate the | delimited list of equivalent servers
Set liveNodes = clusterState.getLiveNodes();
diff --git a/solr/core/src/java/org/apache/solr/schema/FieldType.java b/solr/core/src/java/org/apache/solr/schema/FieldType.java
index ced6220f3a3..d7c54caee52 100644
--- a/solr/core/src/java/org/apache/solr/schema/FieldType.java
+++ b/solr/core/src/java/org/apache/solr/schema/FieldType.java
@@ -541,7 +541,7 @@ public abstract class FieldType extends FieldProperties {
public abstract SortField getSortField(SchemaField field, boolean top);
/**
- * Utility usable by subclasses when they want to get basic String sorting
+ * Utility usable by subclasses when they want to get basic String sorting
* using common checks.
* @see SchemaField#checkSortability
*/
diff --git a/solr/core/src/java/org/apache/solr/schema/RandomSortField.java b/solr/core/src/java/org/apache/solr/schema/RandomSortField.java
index 0a520e5abcb..3ee86674bd6 100644
--- a/solr/core/src/java/org/apache/solr/schema/RandomSortField.java
+++ b/solr/core/src/java/org/apache/solr/schema/RandomSortField.java
@@ -78,7 +78,7 @@ public class RandomSortField extends FieldType {
}
/**
- * Given a field name and an IndexReader, get a random hash seed.
+ * Given a field name and an IndexReader, get a random hash seed.
* Using dynamic fields, you can force the random order to change
*/
private static int getSeed(String fieldName, AtomicReaderContext context) {
diff --git a/solr/core/src/java/org/apache/solr/schema/SchemaField.java b/solr/core/src/java/org/apache/solr/schema/SchemaField.java
index f67667945e4..93a0eab0f5b 100644
--- a/solr/core/src/java/org/apache/solr/schema/SchemaField.java
+++ b/solr/core/src/java/org/apache/solr/schema/SchemaField.java
@@ -159,7 +159,7 @@ public final class SchemaField extends FieldProperties {
/**
* Sanity checks that the properties of this field type are plausible
- * for a field that may be used to get a FieldCacheSource, throwing
+ * for a field that may be used to get a FieldCacheSource, throwing
* an appropriate exception (including the field name) if it is not.
* FieldType subclasses can choose to call this method in their
* getValueSource implementation
diff --git a/solr/core/src/java/org/apache/solr/servlet/SolrDispatchFilter.java b/solr/core/src/java/org/apache/solr/servlet/SolrDispatchFilter.java
index e59fa526efc..8c2ce1dd5e5 100644
--- a/solr/core/src/java/org/apache/solr/servlet/SolrDispatchFilter.java
+++ b/solr/core/src/java/org/apache/solr/servlet/SolrDispatchFilter.java
@@ -40,6 +40,7 @@ import javax.servlet.http.HttpServletResponse;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkNodeProps;
import org.apache.solr.common.cloud.ZkStateReader;
@@ -335,10 +336,10 @@ public class SolrDispatchFilter implements Filter
}
// check everyone then
- Map shards = entry.getValue().getShards();
- Set> shardEntries = shards.entrySet();
- for (Entry shardEntry : shardEntries) {
- ZkNodeProps zkProps = shardEntry.getValue();
+ Map shards = entry.getValue().getReplicasMap();
+ Set> shardEntries = shards.entrySet();
+ for (Entry shardEntry : shardEntries) {
+ Replica zkProps = shardEntry.getValue();
core = checkProps(cores, path, zkProps);
if (core != null) {
break done;
@@ -352,8 +353,8 @@ public class SolrDispatchFilter implements Filter
ZkNodeProps zkProps) {
String corename;
SolrCore core = null;
- if (cores.getZkController().getNodeName().equals(zkProps.get(ZkStateReader.NODE_NAME_PROP))) {
- corename = zkProps.get(ZkStateReader.CORE_NAME_PROP);
+ if (cores.getZkController().getNodeName().equals(zkProps.getStr(ZkStateReader.NODE_NAME_PROP))) {
+ corename = zkProps.getStr(ZkStateReader.CORE_NAME_PROP);
core = cores.getCore(corename);
}
return core;
diff --git a/solr/core/src/java/org/apache/solr/update/processor/DistributedUpdateProcessor.java b/solr/core/src/java/org/apache/solr/update/processor/DistributedUpdateProcessor.java
index 3779040c6ce..eefccfe3306 100644
--- a/solr/core/src/java/org/apache/solr/update/processor/DistributedUpdateProcessor.java
+++ b/solr/core/src/java/org/apache/solr/update/processor/DistributedUpdateProcessor.java
@@ -37,6 +37,7 @@ import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.SolrInputDocument;
import org.apache.solr.common.SolrInputField;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -1062,9 +1063,9 @@ public class DistributedUpdateProcessor extends UpdateRequestProcessor {
for (Map.Entry sliceEntry : slices.entrySet()) {
Slice replicas = slices.get(sliceEntry.getKey());
- Map shardMap = replicas.getShards();
+ Map shardMap = replicas.getReplicasMap();
- for (Entry entry : shardMap.entrySet()) {
+ for (Entry entry : shardMap.entrySet()) {
ZkCoreNodeProps nodeProps = new ZkCoreNodeProps(entry.getValue());
if (clusterState.liveNodesContain(nodeProps.getNodeName()) && !entry.getKey().equals(shardZkNodeName)) {
urls.add(new StdNode(nodeProps));
diff --git a/solr/core/src/java/org/apache/solr/update/processor/FieldMutatingUpdateProcessorFactory.java b/solr/core/src/java/org/apache/solr/update/processor/FieldMutatingUpdateProcessorFactory.java
index 14a4b3d9f57..f68b3cd2e35 100644
--- a/solr/core/src/java/org/apache/solr/update/processor/FieldMutatingUpdateProcessorFactory.java
+++ b/solr/core/src/java/org/apache/solr/update/processor/FieldMutatingUpdateProcessorFactory.java
@@ -68,7 +68,7 @@ import org.apache.solr.util.plugin.SolrCoreAware;
* containing any of the above criteria, identifying fields to be excluded
* from seelction even if they match the selection criteria. As with the main
* selection critiera a field must match all of criteria in a single exclusion
- * in order to be excluded, but multiple exclusions may be specified to get an
+ * in order to be excluded, but multiple exclusions may be specified to get an
* OR
behavior
*
*
diff --git a/solr/core/src/test/org/apache/solr/analysis/TestReversedWildcardFilterFactory.java b/solr/core/src/test/org/apache/solr/analysis/TestReversedWildcardFilterFactory.java
index 60db59b54ba..0a3ff54d3c3 100644
--- a/solr/core/src/test/org/apache/solr/analysis/TestReversedWildcardFilterFactory.java
+++ b/solr/core/src/test/org/apache/solr/analysis/TestReversedWildcardFilterFactory.java
@@ -162,7 +162,7 @@ public class TestReversedWildcardFilterFactory extends SolrTestCaseJ4 {
Query q = qp.parse(query);
if (!(q instanceof AutomatonQuery))
return false;
- // this is a hack to get the protected Automaton field in AutomatonQuery,
+ // this is a hack to get the protected Automaton field in AutomatonQuery,
// may break in later lucene versions - we have no getter... for good reasons.
final Field automatonField = AutomatonQuery.class.getDeclaredField("automaton");
automatonField.setAccessible(true);
diff --git a/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZk2Test.java b/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZk2Test.java
index 8522cc1b2d9..cdb94080482 100644
--- a/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZk2Test.java
+++ b/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZk2Test.java
@@ -34,9 +34,6 @@ import org.apache.solr.common.params.CommonParams;
import org.apache.solr.common.params.ModifiableSolrParams;
import org.apache.solr.servlet.SolrDispatchFilter;
-import com.carrotsearch.randomizedtesting.annotations.ThreadLeakAction;
-import com.carrotsearch.randomizedtesting.annotations.ThreadLeakAction.Action;
-
/**
* This test simply does a bunch of basic things in solrcloud mode and asserts things
* work as expected.
@@ -106,7 +103,7 @@ public class BasicDistributedZk2Test extends AbstractFullDistribZkTestBase {
ZkNodeProps leaderProps = zkStateReader.getLeaderProps(
DEFAULT_COLLECTION, SHARD2);
- String nodeName = leaderProps.get(ZkStateReader.NODE_NAME_PROP);
+ String nodeName = leaderProps.getStr(ZkStateReader.NODE_NAME_PROP);
chaosMonkey.stopShardExcept(SHARD2, nodeName);
SolrServer client = getClient(nodeName);
diff --git a/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZkTest.java b/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZkTest.java
index bfb19682504..6f713165bb6 100644
--- a/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZkTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/BasicDistributedZkTest.java
@@ -58,6 +58,7 @@ import org.apache.solr.common.SolrException;
import org.apache.solr.common.SolrException.ErrorCode;
import org.apache.solr.common.SolrInputDocument;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -70,9 +71,6 @@ import org.apache.solr.common.util.NamedList;
import org.apache.solr.update.SolrCmdDistributor.Request;
import org.apache.solr.util.DefaultSolrThreadFactory;
-import com.carrotsearch.randomizedtesting.annotations.ThreadLeakAction;
-import com.carrotsearch.randomizedtesting.annotations.ThreadLeakAction.Action;
-
/**
* This test simply does a bunch of basic things in solrcloud mode and asserts things
* work as expected.
@@ -462,11 +460,11 @@ public class BasicDistributedZkTest extends AbstractDistribZkTestBase {
Iterator> it = slices.entrySet().iterator();
while (it.hasNext()) {
Entry sliceEntry = it.next();
- Map sliceShards = sliceEntry.getValue().getShards();
- Iterator> shardIt = sliceShards.entrySet()
+ Map sliceShards = sliceEntry.getValue().getReplicasMap();
+ Iterator> shardIt = sliceShards.entrySet()
.iterator();
while (shardIt.hasNext()) {
- Entry shardEntry = shardIt.next();
+ Entry shardEntry = shardIt.next();
ZkCoreNodeProps coreProps = new ZkCoreNodeProps(shardEntry.getValue());
CoreAdminResponse mcr = CoreAdminRequest.getStatus(
coreProps.getCoreName(),
@@ -491,11 +489,11 @@ public class BasicDistributedZkTest extends AbstractDistribZkTestBase {
for (Map.Entry entry : slices.entrySet()) {
Slice slice = entry.getValue();
- Map shards = slice.getShards();
- Set> shardEntries = shards.entrySet();
- for (Map.Entry shardEntry : shardEntries) {
+ Map shards = slice.getReplicasMap();
+ Set> shardEntries = shards.entrySet();
+ for (Map.Entry shardEntry : shardEntries) {
final ZkNodeProps node = shardEntry.getValue();
- if (clusterState.liveNodesContain(node.get(ZkStateReader.NODE_NAME_PROP))) {
+ if (clusterState.liveNodesContain(node.getStr(ZkStateReader.NODE_NAME_PROP))) {
return new ZkCoreNodeProps(node).getCoreUrl();
}
}
@@ -551,13 +549,13 @@ public class BasicDistributedZkTest extends AbstractDistribZkTestBase {
Iterator> it = slices.entrySet().iterator();
while (it.hasNext()) {
Entry sliceEntry = it.next();
- Map sliceShards = sliceEntry.getValue()
- .getShards();
- Iterator> shardIt = sliceShards
+ Map sliceShards = sliceEntry.getValue()
+ .getReplicasMap();
+ Iterator> shardIt = sliceShards
.entrySet().iterator();
while (shardIt.hasNext()) {
- Entry shardEntry = shardIt.next();
- if (!shardEntry.getValue().get(ZkStateReader.STATE_PROP)
+ Entry shardEntry = shardIt.next();
+ if (!shardEntry.getValue().getStr(ZkStateReader.STATE_PROP)
.equals(ZkStateReader.ACTIVE)) {
found = false;
break;
@@ -745,7 +743,7 @@ public class BasicDistributedZkTest extends AbstractDistribZkTestBase {
assertAllActive(oneInstanceCollection2, solrj.getZkStateReader());
- // TODO: enable when we don't falsely get slice1...
+ // TODO: enable when we don't falsely get slice1...
// solrj.getZkStateReader().getLeaderUrl(oneInstanceCollection2, "slice1", 30000);
// solrj.getZkStateReader().getLeaderUrl(oneInstanceCollection2, "slice2", 30000);
client2.add(getDoc(id, "1"));
@@ -780,7 +778,7 @@ public class BasicDistributedZkTest extends AbstractDistribZkTestBase {
zkStateReader.updateClusterState(true);
Map slices = zkStateReader.getClusterState().getSlices(oneInstanceCollection2);
assertNotNull(slices);
- String roles = slices.get("slice1").getShards().values().iterator().next().get(ZkStateReader.ROLES_PROP);
+ String roles = slices.get("slice1").getReplicasMap().values().iterator().next().getStr(ZkStateReader.ROLES_PROP);
assertEquals("none", roles);
}
diff --git a/solr/core/src/test/org/apache/solr/cloud/ClusterStateTest.java b/solr/core/src/test/org/apache/solr/cloud/ClusterStateTest.java
index 9eecf2956fd..613eb52a950 100644
--- a/solr/core/src/test/org/apache/solr/cloud/ClusterStateTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/ClusterStateTest.java
@@ -25,7 +25,7 @@ import java.util.Set;
import org.apache.solr.SolrTestCaseJ4;
import org.apache.solr.common.cloud.ClusterState;
import org.apache.solr.common.cloud.Slice;
-import org.apache.solr.common.cloud.ZkNodeProps;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.ZkStateReader;
import org.junit.Test;
@@ -38,13 +38,13 @@ public class ClusterStateTest extends SolrTestCaseJ4 {
liveNodes.add("node2");
Map slices = new HashMap();
- Map sliceToProps = new HashMap();
- Map props = new HashMap();
+ Map sliceToProps = new HashMap();
+ Map props = new HashMap();
props.put("prop1", "value");
props.put("prop2", "value2");
- ZkNodeProps zkNodeProps = new ZkNodeProps(props);
- sliceToProps.put("node1", zkNodeProps);
+ Replica replica = new Replica("node1", props);
+ sliceToProps.put("node1", replica);
Slice slice = new Slice("shard1", sliceToProps);
slices.put("shard1", slice);
Slice slice2 = new Slice("shard2", sliceToProps);
@@ -60,8 +60,8 @@ public class ClusterStateTest extends SolrTestCaseJ4 {
assertEquals("Provided liveNodes not used properly", 2, loadedClusterState
.getLiveNodes().size());
assertEquals("No collections found", 2, loadedClusterState.getCollections().size());
- assertEquals("Poperties not copied properly", zkNodeProps.get("prop1"), loadedClusterState.getSlice("collection1", "shard1").getShards().get("node1").get("prop1"));
- assertEquals("Poperties not copied properly", zkNodeProps.get("prop2"), loadedClusterState.getSlice("collection1", "shard1").getShards().get("node1").get("prop2"));
+ assertEquals("Poperties not copied properly", replica.getStr("prop1"), loadedClusterState.getSlice("collection1", "shard1").getReplicasMap().get("node1").getStr("prop1"));
+ assertEquals("Poperties not copied properly", replica.getStr("prop2"), loadedClusterState.getSlice("collection1", "shard1").getReplicasMap().get("node1").getStr("prop2"));
loadedClusterState = ClusterState.load(null, new byte[0], liveNodes);
diff --git a/solr/core/src/test/org/apache/solr/cloud/ClusterStateUpdateTest.java b/solr/core/src/test/org/apache/solr/cloud/ClusterStateUpdateTest.java
index bacbb5c3ddc..cfd3ffe4a61 100644
--- a/solr/core/src/test/org/apache/solr/cloud/ClusterStateUpdateTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/ClusterStateUpdateTest.java
@@ -25,6 +25,7 @@ import java.util.Set;
import org.apache.lucene.util.LuceneTestCase.Slow;
import org.apache.solr.SolrTestCaseJ4;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -139,7 +140,7 @@ public class ClusterStateUpdateTest extends SolrTestCaseJ4 {
System.setProperty("solrcloud.update.delay", "1");
- Map props2 = new HashMap();
+ Map props2 = new HashMap();
props2.put("configName", "conf1");
ZkNodeProps zkProps2 = new ZkNodeProps(props2);
@@ -173,7 +174,7 @@ public class ClusterStateUpdateTest extends SolrTestCaseJ4 {
slices = clusterState2.getSlices("testcore");
if (slices != null && slices.containsKey("shard1")
- && slices.get("shard1").getShards().size() > 0) {
+ && slices.get("shard1").getReplicasMap().size() > 0) {
break;
}
Thread.sleep(500);
@@ -185,17 +186,17 @@ public class ClusterStateUpdateTest extends SolrTestCaseJ4 {
Slice slice = slices.get("shard1");
assertEquals("shard1", slice.getName());
- Map shards = slice.getShards();
+ Map shards = slice.getReplicasMap();
assertEquals(1, shards.size());
- ZkNodeProps zkProps = shards.get(host + ":1661_solr_testcore");
+ Replica zkProps = shards.get(host + ":1661_solr_testcore");
assertNotNull(zkProps);
- assertEquals(host + ":1661_solr", zkProps.get(ZkStateReader.NODE_NAME_PROP));
+ assertEquals(host + ":1661_solr", zkProps.getStr(ZkStateReader.NODE_NAME_PROP));
- assertEquals("http://" + host + ":1661/solr", zkProps.get(ZkStateReader.BASE_URL_PROP));
+ assertEquals("http://" + host + ":1661/solr", zkProps.getStr(ZkStateReader.BASE_URL_PROP));
Set liveNodes = clusterState2.getLiveNodes();
assertNotNull(liveNodes);
diff --git a/solr/core/src/test/org/apache/solr/cloud/LeaderElectionIntegrationTest.java b/solr/core/src/test/org/apache/solr/cloud/LeaderElectionIntegrationTest.java
index d55ed7ec9f0..88d5e8b4c08 100644
--- a/solr/core/src/test/org/apache/solr/cloud/LeaderElectionIntegrationTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/LeaderElectionIntegrationTest.java
@@ -249,7 +249,7 @@ public class LeaderElectionIntegrationTest extends SolrTestCaseJ4 {
private String getLeader() throws InterruptedException {
ZkNodeProps props = reader.getLeaderProps("collection1", "shard1", 30000);
- String leader = props.get(ZkStateReader.NODE_NAME_PROP);
+ String leader = props.getStr(ZkStateReader.NODE_NAME_PROP);
return leader;
}
diff --git a/solr/core/src/test/org/apache/solr/cloud/OverseerTest.java b/solr/core/src/test/org/apache/solr/cloud/OverseerTest.java
index 6f954c1e76a..be44ce47d6d 100644
--- a/solr/core/src/test/org/apache/solr/cloud/OverseerTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/OverseerTest.java
@@ -152,7 +152,7 @@ public class OverseerTest extends SolrTestCaseJ4 {
collection);
if (slices != null) {
for (Slice slice : slices.values()) {
- if (slice.getShards().containsKey(nodeName + "_" + coreName)) {
+ if (slice.getReplicasMap().containsKey(nodeName + "_" + coreName)) {
return slice.getName();
}
}
@@ -204,9 +204,9 @@ public class OverseerTest extends SolrTestCaseJ4 {
assertNotNull("shard got no id?", zkController.publishState("core" + (i+1), ZkStateReader.ACTIVE, 3));
}
- assertEquals(2, reader.getClusterState().getSlice("collection1", "shard1").getShards().size());
- assertEquals(2, reader.getClusterState().getSlice("collection1", "shard2").getShards().size());
- assertEquals(2, reader.getClusterState().getSlice("collection1", "shard3").getShards().size());
+ assertEquals(2, reader.getClusterState().getSlice("collection1", "shard1").getReplicasMap().size());
+ assertEquals(2, reader.getClusterState().getSlice("collection1", "shard2").getReplicasMap().size());
+ assertEquals(2, reader.getClusterState().getSlice("collection1", "shard3").getReplicasMap().size());
//make sure leaders are in cloud state
assertNotNull(reader.getLeaderUrl("collection1", "shard1", 15000));
@@ -303,7 +303,7 @@ public class OverseerTest extends SolrTestCaseJ4 {
ClusterState state = reader.getClusterState();
Map slices = state.getSlices("collection1");
for (String name : slices.keySet()) {
- cloudStateSliceCount += slices.get(name).getShards().size();
+ cloudStateSliceCount += slices.get(name).getReplicasMap().size();
}
if (coreCount == cloudStateSliceCount) break;
Thread.sleep(200);
@@ -435,8 +435,8 @@ public class OverseerTest extends SolrTestCaseJ4 {
waitForCollections(reader, "collection1");
assertEquals(reader.getClusterState().toString(), ZkStateReader.RECOVERING,
- reader.getClusterState().getSlice("collection1", "shard1").getShards()
- .get("node1_core1").get(ZkStateReader.STATE_PROP));
+ reader.getClusterState().getSlice("collection1", "shard1").getReplicasMap()
+ .get("node1_core1").getStr(ZkStateReader.STATE_PROP));
//publish node state (active)
m = new ZkNodeProps(Overseer.QUEUE_OPERATION, "state",
@@ -467,7 +467,7 @@ public class OverseerTest extends SolrTestCaseJ4 {
while(maxIterations-->0) {
Slice slice = reader.getClusterState().getSlice("collection1", "shard1");
if(slice!=null) {
- coreState = slice.getShards().get("node1_core1").get(ZkStateReader.STATE_PROP);
+ coreState = slice.getReplicasMap().get("node1_core1").getStr(ZkStateReader.STATE_PROP);
if(coreState.equals(expectedState)) {
return;
}
@@ -483,14 +483,14 @@ public class OverseerTest extends SolrTestCaseJ4 {
reader.updateClusterState(true); // poll state
ZkNodeProps props = reader.getClusterState().getLeader(collection, shard);
if(props!=null) {
- if(expectedCore.equals(props.get(ZkStateReader.CORE_NAME_PROP))) {
+ if(expectedCore.equals(props.getStr(ZkStateReader.CORE_NAME_PROP))) {
return;
}
}
Thread.sleep(100);
}
- assertEquals("Unexpected shard leader coll:" + collection + " shard:" + shard, expectedCore, (reader.getClusterState().getLeader(collection, shard)!=null)?reader.getClusterState().getLeader(collection, shard).get(ZkStateReader.CORE_NAME_PROP):null);
+ assertEquals("Unexpected shard leader coll:" + collection + " shard:" + shard, expectedCore, (reader.getClusterState().getLeader(collection, shard)!=null)?reader.getClusterState().getLeader(collection, shard).getStr(ZkStateReader.CORE_NAME_PROP):null);
}
@Test
@@ -547,7 +547,7 @@ public class OverseerTest extends SolrTestCaseJ4 {
assertEquals("Live nodes count does not match", 1, reader.getClusterState()
.getLiveNodes().size());
assertEquals("Shard count does not match", 1, reader.getClusterState()
- .getSlice("collection1", "shard1").getShards().size());
+ .getSlice("collection1", "shard1").getReplicasMap().size());
version = getClusterStateVersion(controllerClient);
mockController.publishState("core1", null,1);
while(version == getClusterStateVersion(controllerClient));
@@ -714,7 +714,7 @@ public class OverseerTest extends SolrTestCaseJ4 {
int numFound = 0;
for (Map collection : state.getCollectionStates().values()) {
for (Slice slice : collection.values()) {
- if (slice.getShards().get("node1_core1") != null) {
+ if (slice.getReplicasMap().get("node1_core1") != null) {
numFound++;
}
}
@@ -834,11 +834,11 @@ public class OverseerTest extends SolrTestCaseJ4 {
for(int i=0;i<100;i++) {
Slice s = reader.getClusterState().getSlice("collection1", "s1");
- if(s!=null && s.getShards().size()==3) break;
+ if(s!=null && s.getReplicasMap().size()==3) break;
Thread.sleep(100);
}
assertNotNull(reader.getClusterState().getSlice("collection1", "s1"));
- assertEquals(3, reader.getClusterState().getSlice("collection1", "s1").getShards().size());
+ assertEquals(3, reader.getClusterState().getSlice("collection1", "s1").getReplicasMap().size());
} finally {
close(overseerClient);
close(zkClient);
diff --git a/solr/core/src/test/org/apache/solr/cloud/TestHashPartitioner.java b/solr/core/src/test/org/apache/solr/cloud/TestHashPartitioner.java
index 5ff8d19ffab..2ed3f937ff9 100644
--- a/solr/core/src/test/org/apache/solr/cloud/TestHashPartitioner.java
+++ b/solr/core/src/test/org/apache/solr/cloud/TestHashPartitioner.java
@@ -30,7 +30,7 @@ public class TestHashPartitioner extends SolrTestCaseJ4 {
List ranges;
// make sure the partitioner uses the "natural" boundaries and doesn't suffer from an off-by-one
- ranges = hp.partitionRange(2, Integer.MIN_VALUE, Integer.MAX_VALUE);
+ ranges = hp.partitionRange(2, hp.fullRange());
assertEquals(Integer.MIN_VALUE, ranges.get(0).min);
assertEquals(0x80000000, ranges.get(0).min);
assertEquals(0xffffffff, ranges.get(0).max);
@@ -44,7 +44,7 @@ public class TestHashPartitioner extends SolrTestCaseJ4 {
assertEquals(0x7fffffff, ranges.get(1).max);
for (int i = 1; i <= 30000; i += 13) {
- ranges = hp.partitionRange(i, Integer.MIN_VALUE, Integer.MAX_VALUE);
+ ranges = hp.partitionRange(i, hp.fullRange());
assertEquals(i, ranges.size());
assertTrue("First range does not start before " + Integer.MIN_VALUE
+ " it is:" + ranges.get(0).min,
@@ -52,6 +52,14 @@ public class TestHashPartitioner extends SolrTestCaseJ4 {
assertTrue("Last range does not end after " + Integer.MAX_VALUE
+ " it is:" + ranges.get(ranges.size() - 1).max,
ranges.get(ranges.size() - 1).max >= Integer.MAX_VALUE);
+
+ for (Range range : ranges) {
+ String s = range.toString();
+ Range newRange = hp.fromString(s);
+ assertEquals(range, newRange);
+ }
+
+
}
}
diff --git a/solr/core/src/test/org/apache/solr/cloud/ZkCLITest.java b/solr/core/src/test/org/apache/solr/cloud/ZkCLITest.java
index 787eae23506..e246e451be2 100644
--- a/solr/core/src/test/org/apache/solr/cloud/ZkCLITest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/ZkCLITest.java
@@ -20,7 +20,6 @@ package org.apache.solr.cloud;
import java.io.File;
import java.util.List;
-import org.apache.lucene.util.LuceneTestCase.Slow;
import org.apache.solr.SolrTestCaseJ4;
import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -136,7 +135,7 @@ public class ZkCLITest extends SolrTestCaseJ4 {
ZkNodeProps collectionProps = ZkNodeProps.load(zkClient.getData(ZkStateReader.COLLECTIONS_ZKNODE + "/collection1", null, null, true));
assertTrue(collectionProps.containsKey("configName"));
- assertEquals(confsetname, collectionProps.get("configName"));
+ assertEquals(confsetname, collectionProps.getStr("configName"));
// test down config
File confDir = new File(TEMP_DIR,
diff --git a/solr/core/src/test/org/apache/solr/cloud/ZkControllerTest.java b/solr/core/src/test/org/apache/solr/cloud/ZkControllerTest.java
index 42e957f4fa8..f85a9acf97e 100644
--- a/solr/core/src/test/org/apache/solr/cloud/ZkControllerTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/ZkControllerTest.java
@@ -67,7 +67,7 @@ public class ZkControllerTest extends SolrTestCaseJ4 {
zkClient.makePath(ZkController.CONFIGS_ZKNODE + "/" + actualConfigName, true);
- Map props = new HashMap();
+ Map props = new HashMap();
props.put("configName", actualConfigName);
ZkNodeProps zkProps = new ZkNodeProps(props);
zkClient.makePath(ZkStateReader.COLLECTIONS_ZKNODE + "/"
diff --git a/solr/core/src/test/org/apache/solr/cloud/ZkNodePropsTest.java b/solr/core/src/test/org/apache/solr/cloud/ZkNodePropsTest.java
index e01e9007c68..f47091acc8a 100644
--- a/solr/core/src/test/org/apache/solr/cloud/ZkNodePropsTest.java
+++ b/solr/core/src/test/org/apache/solr/cloud/ZkNodePropsTest.java
@@ -30,7 +30,7 @@ public class ZkNodePropsTest extends SolrTestCaseJ4 {
@Test
public void testBasic() throws IOException {
- Map props = new HashMap();
+ Map props = new HashMap();
props.put("prop1", "value1");
props.put("prop2", "value2");
props.put("prop3", "value3");
@@ -42,11 +42,11 @@ public class ZkNodePropsTest extends SolrTestCaseJ4 {
byte[] bytes = ZkStateReader.toJSON(zkProps);
ZkNodeProps props2 = ZkNodeProps.load(bytes);
- assertEquals("value1", props2.get("prop1"));
- assertEquals("value2", props2.get("prop2"));
- assertEquals("value3", props2.get("prop3"));
- assertEquals("value4", props2.get("prop4"));
- assertEquals("value5", props2.get("prop5"));
- assertEquals("value6", props2.get("prop6"));
+ assertEquals("value1", props2.getStr("prop1"));
+ assertEquals("value2", props2.getStr("prop2"));
+ assertEquals("value3", props2.getStr("prop3"));
+ assertEquals("value4", props2.getStr("prop4"));
+ assertEquals("value5", props2.getStr("prop5"));
+ assertEquals("value6", props2.getStr("prop6"));
}
}
diff --git a/solr/core/src/test/org/apache/solr/search/QueryEqualityTest.java b/solr/core/src/test/org/apache/solr/search/QueryEqualityTest.java
index 33e678ce921..258b75fc221 100644
--- a/solr/core/src/test/org/apache/solr/search/QueryEqualityTest.java
+++ b/solr/core/src/test/org/apache/solr/search/QueryEqualityTest.java
@@ -34,7 +34,7 @@ import org.junit.BeforeClass;
* Sanity checks that queries (generated by the QParser and ValueSourceParser
* framework) are appropraitely {@link Object#equals} and
* {@link Object#hashCode()} equivilent. If you are adding a new default
- * QParser or ValueSourceParser, you will most likely get a failure from
+ * QParser or ValueSourceParser, you will most likely get a failure from
* {@link #testParserCoverage} until you add a new test method to this class.
*
* @see ValueSourceParser#standardValueSourceParsers
diff --git a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/BinaryRequestWriter.java b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/BinaryRequestWriter.java
index 2ada3d8344a..36570e857e6 100644
--- a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/BinaryRequestWriter.java
+++ b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/BinaryRequestWriter.java
@@ -104,7 +104,7 @@ public class BinaryRequestWriter extends RequestWriter {
}
/*
- * A hack to get access to the protected internal buffer and avoid an additional copy
+ * A hack to get access to the protected internal buffer and avoid an additional copy
*/
class BAOS extends ByteArrayOutputStream {
byte[] getbuf() {
diff --git a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/CloudSolrServer.java b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/CloudSolrServer.java
index 79bfb1f0b71..be02a47e48e 100644
--- a/solr/solrj/src/java/org/apache/solr/client/solrj/impl/CloudSolrServer.java
+++ b/solr/solrj/src/java/org/apache/solr/client/solrj/impl/CloudSolrServer.java
@@ -208,7 +208,7 @@ public class CloudSolrServer extends SolrServer {
Map nodes = new HashMap();
List urlList = new ArrayList();
for (Slice slice : slices.values()) {
- for (ZkNodeProps nodeProps : slice.getShards().values()) {
+ for (ZkNodeProps nodeProps : slice.getReplicasMap().values()) {
ZkCoreNodeProps coreNodeProps = new ZkCoreNodeProps(nodeProps);
String node = coreNodeProps.getNodeName();
if (!liveNodes.contains(coreNodeProps.getNodeName())
diff --git a/solr/solrj/src/java/org/apache/solr/client/solrj/response/QueryResponse.java b/solr/solrj/src/java/org/apache/solr/client/solrj/response/QueryResponse.java
index 20a312bc3d9..4c03bb1f006 100644
--- a/solr/solrj/src/java/org/apache/solr/client/solrj/response/QueryResponse.java
+++ b/solr/solrj/src/java/org/apache/solr/client/solrj/response/QueryResponse.java
@@ -443,7 +443,7 @@ public class QueryResponse extends SolrResponseBase
return _facetPivot;
}
- /** get
+ /** get
*
* @param name the name of the
* @return the FacetField by name or null if it does not exist
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/ClusterState.java b/solr/solrj/src/java/org/apache/solr/common/cloud/ClusterState.java
index cf23d1c6d97..8a255918cd9 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/ClusterState.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/ClusterState.java
@@ -92,9 +92,9 @@ public class ClusterState implements JSONWriter.Writable {
Set> slices = state.entrySet();
for (Entry sliceEntry : slices) {
Slice slice = sliceEntry.getValue();
- Map shards = slice.getShards();
- Set> shardsEntries = shards.entrySet();
- for (Entry shardEntry : shardsEntries) {
+ Map shards = slice.getReplicasMap();
+ Set> shardsEntries = shards.entrySet();
+ for (Entry shardEntry : shardsEntries) {
ZkNodeProps props = shardEntry.getValue();
if (props.containsKey(ZkStateReader.LEADER_PROP)) {
Map leadersForCollection = leaders.get(collection.getKey());
@@ -122,11 +122,11 @@ public class ClusterState implements JSONWriter.Writable {
/**
* Get shard properties or null if shard is not found.
*/
- public ZkNodeProps getShardProps(final String collection, final String coreNodeName) {
+ public Replica getShardProps(final String collection, final String coreNodeName) {
Map slices = getSlices(collection);
for(Slice slice: slices.values()) {
- if(slice.getShards().get(coreNodeName)!=null) {
- return slice.getShards().get(coreNodeName);
+ if(slice.getReplicasMap().get(coreNodeName)!=null) {
+ return slice.getReplicasMap().get(coreNodeName);
}
}
return null;
@@ -185,7 +185,7 @@ public class ClusterState implements JSONWriter.Writable {
public String getShardId(String coreNodeName) {
for (Entry> states: collectionStates.entrySet()){
for(Entry slices: states.getValue().entrySet()) {
- for(Entry shards: slices.getValue().getShards().entrySet()){
+ for(Entry shards: slices.getValue().getReplicasMap().entrySet()){
if(coreNodeName.equals(shards.getKey())) {
return slices.getKey();
}
@@ -294,10 +294,10 @@ public class ClusterState implements JSONWriter.Writable {
Map collection = (Map)stateMap.get(collectionName);
Map slices = new LinkedHashMap();
for(String sliceName: collection.keySet()) {
- Map> sliceMap = (Map>)collection.get(sliceName);
- Map shards = new LinkedHashMap();
+ Map> sliceMap = (Map>)collection.get(sliceName);
+ Map shards = new LinkedHashMap();
for(String shardName: sliceMap.keySet()) {
- shards.put(shardName, new ZkNodeProps(sliceMap.get(shardName)));
+ shards.put(shardName, new Replica(shardName, sliceMap.get(shardName)));
}
Slice slice = new Slice(sliceName, shards);
slices.put(sliceName, slice);
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/HashPartitioner.java b/solr/solrj/src/java/org/apache/solr/common/cloud/HashPartitioner.java
index f55f1132a8a..0ed9873caa9 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/HashPartitioner.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/HashPartitioner.java
@@ -17,23 +17,26 @@ package org.apache.solr.common.cloud;
* limitations under the License.
*/
+import org.apache.noggit.JSONWriter;
+
import java.util.ArrayList;
import java.util.List;
/**
* Class to partition int range into n ranges.
- *
+ *
*/
public class HashPartitioner {
// Hash ranges can't currently "wrap" - i.e. max must be greater or equal to min.
// TODO: ranges may not be all contiguous in the future (either that or we will
// need an extra class to model a collection of ranges)
- public static class Range {
+ public static class Range implements JSONWriter.Writable {
public int min; // inclusive
public int max; // inclusive
-
+
public Range(int min, int max) {
+ assert min <= max;
this.min = min;
this.max = max;
}
@@ -46,12 +49,39 @@ public class HashPartitioner {
return Integer.toHexString(min) + '-' + Integer.toHexString(max);
}
- public static Range fromString(String range) {
- return null; // TODO
+
+ @Override
+ public int hashCode() {
+ // difficult numbers to hash... only the highest bits will tend to differ.
+ // ranges will only overlap during a split, so we can just hash the lower range.
+ return (min>>28) + (min>>25) + (min>>21) + min;
+ }
+
+ @Override
+ public boolean equals(Object obj) {
+ if (obj.getClass() != getClass()) return false;
+ Range other = (Range)obj;
+ return this.min == other.min && this.max == other.max;
+ }
+
+ @Override
+ public void write(JSONWriter writer) {
+ writer.write(toString());
}
}
+ public Range fromString(String range) {
+ int middle = range.indexOf('-');
+ String minS = range.substring(0, middle);
+ String maxS = range.substring(middle+1);
+ long min = Long.parseLong(minS, 16); // use long to prevent the parsing routines from potentially worrying about overflow
+ long max = Long.parseLong(maxS, 16);
+ return new Range((int)min, (int)max);
+ }
+ public Range fullRange() {
+ return new Range(Integer.MIN_VALUE, Integer.MAX_VALUE);
+ }
public List partitionRange(int partitions, Range range) {
return partitionRange(partitions, range.min, range.max);
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/Replica.java b/solr/solrj/src/java/org/apache/solr/common/cloud/Replica.java
new file mode 100644
index 00000000000..5c8bf7de78a
--- /dev/null
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/Replica.java
@@ -0,0 +1,38 @@
+package org.apache.solr.common.cloud;
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import java.util.Map;
+
+
+public class Replica extends ZkNodeProps {
+ private final String name;
+
+ public Replica(String name, Map propMap) { // TODO: back compat for handling Map
+ super(propMap);
+ this.name = name;
+ String nodeName = (String)propMap.get(ZkStateReader.NODE_NAME_PROP);
+ assert nodeName == null || name.startsWith(nodeName);
+ }
+
+ public String getName() {
+ return name;
+ }
+
+
+}
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/Slice.java b/solr/solrj/src/java/org/apache/solr/common/cloud/Slice.java
index bb64b849db5..1487862f70f 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/Slice.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/Slice.java
@@ -19,46 +19,72 @@ package org.apache.solr.common.cloud;
import org.apache.noggit.JSONWriter;
-import java.util.Collections;
+import java.util.Collection;
import java.util.HashMap;
+import java.util.LinkedHashMap;
import java.util.Map;
/**
- * A Slice contains immutable information about all shards that share the same
- * shard id (shard leader and replicas).
+ * A Slice contains immutable information about a logical shard (all replicas that share the same shard id).
*/
-public class Slice implements JSONWriter.Writable {
- private final Map shards;
+public class Slice extends ZkNodeProps {
+ public static String REPLICAS = "replicas";
+ public static String RANGE = "range";
+ public static String LEADER = "leader";
+
private final String name;
+ private final HashPartitioner.Range range;
+ // private final Integer replicationFactor;
+ private final Map replicas;
+ private final Replica leader;
- public Slice(String name, Map shards) {
- this.shards = shards;
+ public Slice(String name, Map replicas) {
+ this(name, replicas, null);
+ }
+
+ public Slice(String name, Map replicas, Map props) {
+ super( props==null ? new LinkedHashMap(2) : new LinkedHashMap(props));
this.name = name;
- }
-
- /**
- * Get properties for all shards in this slice.
- *
- * @return map containing coreNodeName as the key, see
- * {@link ZkStateReader#getCoreNodeName(String, String)}, ZKNodeProps
- * as the value.
- */
- public Map getShards() {
- return Collections.unmodifiableMap(shards);
+ this.replicas = replicas != null ? replicas : makeReplicas((Map)propMap.get(REPLICAS));
+ propMap.put(REPLICAS, replicas);
+
+ String rangeStr = (String)propMap.get(RANGE);
+ HashPartitioner.Range tmpRange = null;
+ if (rangeStr != null) {
+ HashPartitioner hp = new HashPartitioner();
+ tmpRange = hp.fromString(rangeStr);
+ }
+
+ range = tmpRange;
+ // replicationFactor = null; // future
+ leader = findLeader();
}
- /**
- * Get a copy of the shards data this object holds.
- */
- public Map getShardsCopy() {
- Map shards = new HashMap();
- for (Map.Entry entry : this.shards.entrySet()) {
- ZkNodeProps zkProps = new ZkNodeProps(entry.getValue());
- shards.put(entry.getKey(), zkProps);
+
+ private Map makeReplicas(Map genericReplicas) {
+ if (genericReplicas == null) return new HashMap(1);
+ Map result = new LinkedHashMap(genericReplicas.size());
+ for (Map.Entry entry : genericReplicas.entrySet()) {
+ String name = entry.getKey();
+ Object val = entry.getValue();
+ Replica r;
+ if (val instanceof Replica) {
+ r = (Replica)val;
+ } else {
+ r = new Replica(name, (Map)val);
+ }
+ result.put(name, r);
}
- return shards;
+ return result;
}
-
+
+ private Replica findLeader() {
+ for (Replica replica : replicas.values()) {
+ if (replica.getStr(LEADER) != null) return replica;
+ }
+ return null;
+ }
+
/**
* Return slice name (shard id).
*/
@@ -66,13 +92,57 @@ public class Slice implements JSONWriter.Writable {
return name;
}
+ /**
+ * Gets the list of replicas for this slice.
+ */
+ public Collection getReplicas() {
+ return replicas.values();
+ }
+
+ /**
+ * Get the map of coreNodeName to replicas for this slice.
+ *
+ * @return map containing coreNodeName as the key, see
+ * {@link ZkStateReader#getCoreNodeName(String, String)}, Replica
+ * as the value.
+ */
+ public Map getReplicasMap() {
+ return replicas;
+ }
+
+ public Map getReplicasCopy() {
+ return new LinkedHashMap(replicas);
+ }
+
+ public Replica getLeader() {
+ return leader;
+ }
+
+ /***
+ // returns a copy of this slice containing the new replica
+ public Slice addReplica(Replica replica) {
+ Map newProps = new LinkedHashMap(props);
+ Map replicas = getReplicasMap();
+ Map newReplicas = replicas == null ? new HashMap(1) : new LinkedHashMap(replicas);
+// newReplicas.put(replica.getName(), replica);
+ newProps.put(REPLICAS, replicas);
+ return new Slice(name, newProps); // TODO: new constructor that takes replicas as-is w/o rebuilding
+ }
+
+ public static Slice newSlice(String name) {
+ Map props = new HashMap(1);
+ props.put("replicas", new HashMap(1));
+ return new Slice(name, props);
+ }
+ ***/
+
@Override
public String toString() {
- return "Slice [shards=" + shards + ", name=" + name + "]";
+ return "Slice [replicas=" + replicas + ", name=" + name + "]";
}
@Override
public void write(JSONWriter jsonWriter) {
- jsonWriter.write(shards);
+ jsonWriter.write(replicas);
}
}
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkCoreNodeProps.java b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkCoreNodeProps.java
index facb216bcfb..98b99565bb3 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkCoreNodeProps.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkCoreNodeProps.java
@@ -25,27 +25,27 @@ public class ZkCoreNodeProps {
}
public String getCoreUrl() {
- return getCoreUrl(nodeProps.get(ZkStateReader.BASE_URL_PROP), nodeProps.get(ZkStateReader.CORE_NAME_PROP));
+ return getCoreUrl(nodeProps.getStr(ZkStateReader.BASE_URL_PROP), nodeProps.getStr(ZkStateReader.CORE_NAME_PROP));
}
public String getNodeName() {
- return nodeProps.get(ZkStateReader.NODE_NAME_PROP);
+ return nodeProps.getStr(ZkStateReader.NODE_NAME_PROP);
}
public String getState() {
- return nodeProps.get(ZkStateReader.STATE_PROP);
+ return nodeProps.getStr(ZkStateReader.STATE_PROP);
}
public String getBaseUrl() {
- return nodeProps.get(ZkStateReader.BASE_URL_PROP);
+ return nodeProps.getStr(ZkStateReader.BASE_URL_PROP);
}
public String getCoreName() {
- return nodeProps.get(ZkStateReader.CORE_NAME_PROP);
+ return nodeProps.getStr(ZkStateReader.CORE_NAME_PROP);
}
public static String getCoreUrl(ZkNodeProps nodeProps) {
- return getCoreUrl(nodeProps.get(ZkStateReader.BASE_URL_PROP), nodeProps.get(ZkStateReader.CORE_NAME_PROP));
+ return getCoreUrl(nodeProps.getStr(ZkStateReader.BASE_URL_PROP), nodeProps.getStr(ZkStateReader.CORE_NAME_PROP));
}
public static String getCoreUrl(String baseUrl, String coreName) {
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkNodeProps.java b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkNodeProps.java
index a89e6e071e6..28ab500fcd0 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkNodeProps.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkNodeProps.java
@@ -17,51 +17,54 @@ package org.apache.solr.common.cloud;
* limitations under the License.
*/
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Set;
-import java.util.Map.Entry;
-
import org.apache.noggit.JSONWriter;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.LinkedHashMap;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+
/**
- * ZkNodeProps contains immutable properties for a shard/solr core.
+ * ZkNodeProps contains generic immutable properties.
*/
public class ZkNodeProps implements JSONWriter.Writable {
- private final Map propMap;
+ protected final Map propMap;
/**
* Construct ZKNodeProps from map.
*/
- public ZkNodeProps(Map propMap) {
- this.propMap = new HashMap();
- this.propMap.putAll(propMap);
+ public ZkNodeProps(Map propMap) { // TODO: back compat for handling Map
+ this.propMap = propMap;
}
-
- /**
- * Construct ZKNodeProps from information of an existingZKNodeProps.
- */
- public ZkNodeProps(ZkNodeProps zkNodeProps) {
- this.propMap = new HashMap();
- this.propMap.putAll(zkNodeProps.propMap);
- }
-
+
+
/**
* Constructor that populates the from array of Strings in form key1, value1,
* key2, value2, ..., keyN, valueN
*/
public ZkNodeProps(String... keyVals) {
- if (keyVals.length % 2 != 0) {
+ this( makeMap(keyVals) );
+ }
+
+ public static ZkNodeProps fromKeyVals(Object... keyVals) {
+ return new ZkNodeProps( makeMap(keyVals) );
+ }
+
+ public static Map makeMap(Object... keyVals) {
+ if ((keyVals.length & 0x01) != 0) {
throw new IllegalArgumentException("arguments should be key,value");
}
- propMap = new HashMap();
+ Map propMap = new HashMap(keyVals.length>>1);
for (int i = 0; i < keyVals.length; i+=2) {
- propMap.put(keyVals[i], keyVals[i+1]);
+ propMap.put(keyVals[i].toString(), keyVals[i+1]);
}
+ return propMap;
}
-
+
+
/**
* Get property keys.
*/
@@ -72,15 +75,20 @@ public class ZkNodeProps implements JSONWriter.Writable {
/**
* Get all properties as map.
*/
- public Map getProperties() {
+ public Map getProperties() {
return Collections.unmodifiableMap(propMap);
}
+ /** Returns a shallow writable copy of the properties */
+ public Map shallowCopy() {
+ return new LinkedHashMap(propMap);
+ }
+
/**
- * Create ZkNodeProps from json string that is typically stored in zookeeper.
+ * Create Replica from json string that is typically stored in zookeeper.
*/
public static ZkNodeProps load(byte[] bytes) {
- Map props = (Map) ZkStateReader.fromJSON(bytes);
+ Map props = (Map) ZkStateReader.fromJSON(bytes);
return new ZkNodeProps(props);
}
@@ -90,17 +98,22 @@ public class ZkNodeProps implements JSONWriter.Writable {
}
/**
- * Get property value.
+ * Get a string property value.
*/
- public String get(String key) {
+ public String getStr(String key) {
+ Object o = propMap.get(key);
+ return o == null ? null : o.toString();
+ }
+
+ public Object get(String key,int foo) {
return propMap.get(key);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
- Set> entries = propMap.entrySet();
- for(Entry entry : entries) {
+ Set> entries = propMap.entrySet();
+ for(Entry entry : entries) {
sb.append(entry.getKey() + "=" + entry.getValue() + "\n");
}
return sb.toString();
diff --git a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkStateReader.java b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkStateReader.java
index 8b4e2cb6740..1f7189ab811 100644
--- a/solr/solrj/src/java/org/apache/solr/common/cloud/ZkStateReader.java
+++ b/solr/solrj/src/java/org/apache/solr/common/cloud/ZkStateReader.java
@@ -458,10 +458,10 @@ public class ZkStateReader {
throw new ZooKeeperException(ErrorCode.BAD_REQUEST, "Could not find shardId in zk: " + shardId);
}
- Map shardMap = replicas.getShards();
+ Map shardMap = replicas.getReplicasMap();
List nodes = new ArrayList(shardMap.size());
String filterNodeName = thisNodeName + "_" + coreName;
- for (Entry entry : shardMap.entrySet()) {
+ for (Entry entry : shardMap.entrySet()) {
ZkCoreNodeProps nodeProps = new ZkCoreNodeProps(entry.getValue());
String coreNodeName = nodeProps.getNodeName() + "_" + nodeProps.getCoreName();
if (clusterState.liveNodesContain(nodeProps.getNodeName()) && !coreNodeName.equals(filterNodeName)) {
diff --git a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractDistribZkTestBase.java b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractDistribZkTestBase.java
index c89ee8f4009..8b6a35b5045 100644
--- a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractDistribZkTestBase.java
+++ b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractDistribZkTestBase.java
@@ -24,11 +24,10 @@ import java.util.concurrent.atomic.AtomicInteger;
import org.apache.commons.io.FileUtils;
import org.apache.solr.BaseDistributedSearchTestCase;
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
-import org.apache.solr.cloud.ZkTestServer;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.SolrZkClient;
-import org.apache.solr.common.cloud.ZkNodeProps;
import org.apache.solr.common.cloud.ZkStateReader;
import org.apache.solr.servlet.SolrDispatchFilter;
import org.apache.zookeeper.KeeperException;
@@ -130,18 +129,18 @@ public abstract class AbstractDistribZkTestBase extends BaseDistributedSearchTes
ClusterState clusterState = zkStateReader.getClusterState();
Map slices = clusterState.getSlices(collection);
for (Map.Entry entry : slices.entrySet()) {
- Map shards = entry.getValue().getShards();
- for (Map.Entry shard : shards.entrySet()) {
+ Map shards = entry.getValue().getReplicasMap();
+ for (Map.Entry shard : shards.entrySet()) {
if (verbose) System.out.println("rstate:"
- + shard.getValue().get(ZkStateReader.STATE_PROP)
+ + shard.getValue().getStr(ZkStateReader.STATE_PROP)
+ " live:"
- + clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP)));
- String state = shard.getValue().get(ZkStateReader.STATE_PROP);
+ + clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP)));
+ String state = shard.getValue().getStr(ZkStateReader.STATE_PROP);
if ((state.equals(ZkStateReader.RECOVERING) || state
.equals(ZkStateReader.SYNC) || state.equals(ZkStateReader.DOWN))
- && clusterState.liveNodesContain(shard.getValue().get(
- ZkStateReader.NODE_NAME_PROP))) {
+ && clusterState.liveNodesContain(shard.getValue().getStr(
+ ZkStateReader.NODE_NAME_PROP))) {
sawLiveRecovering = true;
}
}
@@ -176,10 +175,10 @@ public abstract class AbstractDistribZkTestBase extends BaseDistributedSearchTes
throw new IllegalArgumentException("Cannot find collection:" + collection);
}
for (Map.Entry entry : slices.entrySet()) {
- Map shards = entry.getValue().getShards();
- for (Map.Entry shard : shards.entrySet()) {
+ Map shards = entry.getValue().getReplicasMap();
+ for (Map.Entry shard : shards.entrySet()) {
- String state = shard.getValue().get(ZkStateReader.STATE_PROP);
+ String state = shard.getValue().getStr(ZkStateReader.STATE_PROP);
if (!state.equals(ZkStateReader.ACTIVE)) {
fail("Not all shards are ACTIVE - found a shard that is: " + state);
}
diff --git a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractFullDistribZkTestBase.java b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractFullDistribZkTestBase.java
index 017f0bc003b..49b21fa3691 100644
--- a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractFullDistribZkTestBase.java
+++ b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractFullDistribZkTestBase.java
@@ -45,6 +45,7 @@ import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.SolrInputDocument;
import org.apache.solr.common.cloud.ClusterState;
+import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkCoreNodeProps;
import org.apache.solr.common.cloud.ZkNodeProps;
@@ -340,7 +341,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
Map slices = this.zkStateReader.getClusterState().getSlices(defaultCollection);
int cnt = 0;
for (Map.Entry entry : slices.entrySet()) {
- cnt += entry.getValue().getShards().size();
+ cnt += entry.getValue().getReplicasMap().size();
}
return cnt;
@@ -378,8 +379,8 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
nextClient:
// we find ou state by simply matching ports...
for (Map.Entry slice : slices.entrySet()) {
- Map theShards = slice.getValue().getShards();
- for (Map.Entry shard : theShards.entrySet()) {
+ Map theShards = slice.getValue().getReplicasMap();
+ for (Map.Entry shard : theShards.entrySet()) {
int port = new URI(((HttpSolrServer) client).getBaseURL())
.getPort();
@@ -387,7 +388,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
CloudSolrServerClient csc = new CloudSolrServerClient();
csc.solrClient = client;
csc.port = port;
- csc.shardName = shard.getValue().get(ZkStateReader.NODE_NAME_PROP);
+ csc.shardName = shard.getValue().getStr(ZkStateReader.NODE_NAME_PROP);
csc.info = shard.getValue();
theClients .add(csc);
@@ -406,8 +407,8 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
nextJetty:
for (Map.Entry slice : slices.entrySet()) {
- Map theShards = slice.getValue().getShards();
- for (Map.Entry shard : theShards.entrySet()) {
+ Map theShards = slice.getValue().getReplicasMap();
+ for (Map.Entry shard : theShards.entrySet()) {
if (shard.getKey().contains(":" + port + "_")) {
List list = shardToJetty.get(slice.getKey());
if (list == null) {
@@ -419,9 +420,9 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
CloudJettyRunner cjr = new CloudJettyRunner();
cjr.jetty = jetty;
cjr.info = shard.getValue();
- cjr.nodeName = shard.getValue().get(ZkStateReader.NODE_NAME_PROP);
+ cjr.nodeName = shard.getValue().getStr(ZkStateReader.NODE_NAME_PROP);
cjr.coreNodeName = shard.getKey();
- cjr.url = shard.getValue().get(ZkStateReader.BASE_URL_PROP) + "/" + shard.getValue().get(ZkStateReader.CORE_NAME_PROP);
+ cjr.url = shard.getValue().getStr(ZkStateReader.BASE_URL_PROP) + "/" + shard.getValue().getStr(ZkStateReader.CORE_NAME_PROP);
cjr.client = findClientByPort(port, theClients);
list.add(cjr);
if (isLeader) {
@@ -442,7 +443,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
List jetties = shardToJetty.get(slice.getKey());
assertNotNull("Test setup problem: We found no jetties for shard: " + slice.getKey()
+ " just:" + shardToJetty.keySet(), jetties);
- assertEquals(slice.getValue().getShards().size(), jetties.size());
+ assertEquals(slice.getValue().getReplicasMap().size(), jetties.size());
}
}
@@ -752,7 +753,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
"The client count does not match up with the shard count for slice:"
+ shard,
zkStateReader.getClusterState().getSlice(DEFAULT_COLLECTION, shard)
- .getShards().size(), solrJetties.size());
+ .getReplicasMap().size(), solrJetties.size());
CloudJettyRunner lastJetty = null;
for (CloudJettyRunner cjetty : solrJetties) {
@@ -775,7 +776,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
}
boolean live = false;
- String nodeName = props.get(ZkStateReader.NODE_NAME_PROP);
+ String nodeName = props.getStr(ZkStateReader.NODE_NAME_PROP);
if (zkStateReader.getClusterState().liveNodesContain(nodeName)) {
live = true;
}
@@ -783,7 +784,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
if (verbose) System.err.println(" num:" + num + "\n");
- boolean active = props.get(ZkStateReader.STATE_PROP).equals(
+ boolean active = props.getStr(ZkStateReader.STATE_PROP).equals(
ZkStateReader.ACTIVE);
if (active && live) {
if (lastNum > -1 && lastNum != num && failMessage == null) {
@@ -877,7 +878,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
CloudJettyRunner cjetty = shardToJetty.get(s).get(i);
ZkNodeProps props = cjetty.info;
SolrServer client = cjetty.client.solrClient;
- boolean active = props.get(ZkStateReader.STATE_PROP).equals(
+ boolean active = props.getStr(ZkStateReader.STATE_PROP).equals(
ZkStateReader.ACTIVE);
if (active) {
SolrQuery query = new SolrQuery("*:*");
@@ -886,7 +887,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
if (verbose) System.err.println(new ZkCoreNodeProps(props)
.getCoreUrl() + " : " + results);
if (verbose) System.err.println("shard:"
- + props.get(ZkStateReader.SHARD_ID_PROP));
+ + props.getStr(ZkStateReader.SHARD_ID_PROP));
cnt += results;
break;
}
@@ -948,8 +949,8 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
for (CloudJettyRunner cjetty : cloudJettys) {
CloudSolrServerClient client = cjetty.client;
for (Map.Entry slice : slices.entrySet()) {
- Map theShards = slice.getValue().getShards();
- for (Map.Entry shard : theShards.entrySet()) {
+ Map theShards = slice.getValue().getReplicasMap();
+ for (Map.Entry shard : theShards.entrySet()) {
String shardName = new URI(
((HttpSolrServer) client.solrClient).getBaseURL()).getPort()
+ "_solr_";
@@ -961,11 +962,11 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
}
long count = 0;
- String currentState = cjetty.info.get(ZkStateReader.STATE_PROP);
+ String currentState = cjetty.info.getStr(ZkStateReader.STATE_PROP);
if (currentState != null
&& currentState.equals(ZkStateReader.ACTIVE)
&& zkStateReader.getClusterState().liveNodesContain(
- cjetty.info.get(ZkStateReader.NODE_NAME_PROP))) {
+ cjetty.info.getStr(ZkStateReader.NODE_NAME_PROP))) {
SolrQuery query = new SolrQuery("*:*");
query.set("distrib", false);
count = client.solrClient.query(query).getResults().getNumFound();
@@ -1209,7 +1210,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
CloudJettyRunner cjetty) throws InterruptedException {
int tries = 0;
while (zkStateReader.getClusterState()
- .liveNodesContain(cjetty.info.get(ZkStateReader.NODE_NAME_PROP))) {
+ .liveNodesContain(cjetty.info.getStr(ZkStateReader.NODE_NAME_PROP))) {
if (tries++ == 120) {
fail("Shard still reported as live in zk");
}
diff --git a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractZkTestCase.java b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractZkTestCase.java
index f248ad76582..1a4d5929a01 100644
--- a/solr/test-framework/src/java/org/apache/solr/cloud/AbstractZkTestCase.java
+++ b/solr/test-framework/src/java/org/apache/solr/cloud/AbstractZkTestCase.java
@@ -93,7 +93,7 @@ public abstract class AbstractZkTestCase extends SolrTestCaseJ4 {
zkClient = new SolrZkClient(zkAddress, AbstractZkTestCase.TIMEOUT);
- Map props = new HashMap();
+ Map props = new HashMap();
props.put("configName", "conf1");
final ZkNodeProps zkProps = new ZkNodeProps(props);
diff --git a/solr/test-framework/src/java/org/apache/solr/cloud/ChaosMonkey.java b/solr/test-framework/src/java/org/apache/solr/cloud/ChaosMonkey.java
index 94bb2b33024..ac518ad017b 100644
--- a/solr/test-framework/src/java/org/apache/solr/cloud/ChaosMonkey.java
+++ b/solr/test-framework/src/java/org/apache/solr/cloud/ChaosMonkey.java
@@ -259,13 +259,13 @@ public class ChaosMonkey {
Slice theShards = zkStateReader.getClusterState().getSlices(collection)
.get(slice);
- ZkNodeProps props = theShards.getShards().get(cloudJetty.coreNodeName);
+ ZkNodeProps props = theShards.getReplicasMap().get(cloudJetty.coreNodeName);
if (props == null) {
- throw new RuntimeException("shard name " + cloudJetty.coreNodeName + " not found in " + theShards.getShards().keySet());
+ throw new RuntimeException("shard name " + cloudJetty.coreNodeName + " not found in " + theShards.getReplicasMap().keySet());
}
- String state = props.get(ZkStateReader.STATE_PROP);
- String nodeName = props.get(ZkStateReader.NODE_NAME_PROP);
+ String state = props.getStr(ZkStateReader.STATE_PROP);
+ String nodeName = props.getStr(ZkStateReader.NODE_NAME_PROP);
if (!cloudJetty.jetty.isRunning()
@@ -309,7 +309,7 @@ public class ChaosMonkey {
cjetty = jetties.get(index);
ZkNodeProps leader = zkStateReader.getLeaderProps(collection, slice);
- boolean isLeader = leader.get(ZkStateReader.NODE_NAME_PROP).equals(jetties.get(index).nodeName);
+ boolean isLeader = leader.getStr(ZkStateReader.NODE_NAME_PROP).equals(jetties.get(index).nodeName);
if (!aggressivelyKillLeaders && isLeader) {
// we don't kill leaders...
monkeyLog("abort! I don't kill leaders");