SOLR-4816: deal with leader=null case and init map with known size

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1524170 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Mark Robert Miller 2013-09-17 18:45:39 +00:00
parent 60f1e5eb54
commit 7684f2b73d
1 changed files with 9 additions and 1 deletions

View File

@ -302,6 +302,10 @@ public class CloudSolrServer extends SolrServer {
//The value is a list of URLs for each replica in the slice. //The value is a list of URLs for each replica in the slice.
//The first value in the list is the leader for the slice. //The first value in the list is the leader for the slice.
Map<String,List<String>> urlMap = buildUrlMap(col); Map<String,List<String>> urlMap = buildUrlMap(col);
if (urlMap == null) {
// we could not find a leader yet - use unoptimized general path
return null;
}
NamedList exceptions = new NamedList(); NamedList exceptions = new NamedList();
NamedList shardResponses = new NamedList(); NamedList shardResponses = new NamedList();
@ -314,7 +318,7 @@ public class CloudSolrServer extends SolrServer {
long start = System.nanoTime(); long start = System.nanoTime();
if (parallelUpdates) { if (parallelUpdates) {
final Map<String, Future<NamedList<?>>> responseFutures = new HashMap<String, Future<NamedList<?>>>(); final Map<String, Future<NamedList<?>>> responseFutures = new HashMap<String, Future<NamedList<?>>>(routes.size());
for (final Map.Entry<String, LBHttpSolrServer.Req> entry : routes.entrySet()) { for (final Map.Entry<String, LBHttpSolrServer.Req> entry : routes.entrySet()) {
final String url = entry.getKey(); final String url = entry.getKey();
final LBHttpSolrServer.Req lbRequest = entry.getValue(); final LBHttpSolrServer.Req lbRequest = entry.getValue();
@ -402,6 +406,10 @@ public class CloudSolrServer extends SolrServer {
String name = slice.getName(); String name = slice.getName();
List<String> urls = new ArrayList<String>(); List<String> urls = new ArrayList<String>();
Replica leader = slice.getLeader(); Replica leader = slice.getLeader();
if (leader == null) {
// take unoptimized general path - we cannot find a leader yet
return null;
}
ZkCoreNodeProps zkProps = new ZkCoreNodeProps(leader); ZkCoreNodeProps zkProps = new ZkCoreNodeProps(leader);
String url = zkProps.getBaseUrl() + "/" + col.getName(); String url = zkProps.getBaseUrl() + "/" + col.getName();
urls.add(url); urls.add(url);