我尝试使用CloudSolrServer在SolrCloud上上传文档时遇到异常。
Exception in thread "main" org.apache.solr.common.SolrException: Could not find collection : gettingstarted
at org.apache.solr.common.cloud.ClusterState.getCollection(ClusterState.java:162)
at org.apache.solr.client.solrj.impl.CloudSolrServer.directUpdate(CloudSolrServer.java:305)
at org.apache.solr.client.solrj.impl.CloudSolrServer.request(CloudSolrServer.java:533)
at org.apache.solr.client.solrj.request.AbstractUpdateRequest.process(AbstractUpdateRequest.java:124)
at org.apache.solr.client.solrj.SolrServer.add(SolrServer.java:116)
at org.apache.solr.client.solrj.SolrServer.add(SolrServer.java:102)
at Test.addDocumentSolrCloud(Test.java:265)
at Test.main(Test.java:284)
该集合存在,我可以使用Solr admin进行查询。并且还能够使用HttpSolrServer上传文档(单实例 - 非云模式)。
我正在使用以下代码段
CloudSolrServer server = new CloudSolrServer("localhost:2181");
server.setDefaultCollection("gettingstarted");
SolrInputDocument doc = new SolrInputDocument();
doc.addField("id", id);
doc.addField("name", name);
server.add(doc);
server.commit();
不确定我缺少什么。我的Zookeeper在同一台机器上运行,其中两个solr云节点都是
答案 0 :(得分:3)
我能够找出问题所在。事实上,集群/云是正确配置的,但SolrJ-4.x不能与Solr 5.0.0一起使用;特别是Cloud Solr API;除了云之外,使用HttpSolrServer的其他查询产生了结果。
我切换到SolrJ-5.0.0并修改了以下代码段:
CloudSolrClient cloudSolrClient = new CloudSolrClient("localhost:2181") ;
cloudSolrClient.setDefaultCollection("gettingstarted");
SolrInputDocument doc = new SolrInputDocument();
doc.addField("id", id);
doc.addField("name", name);
cloudSolrClient.add(doc);
cloudSolrClient.commit();
API已更改/重构
的Adnan