CloudSolrServer:无法找到集合:gettingstarted

时间:2015-03-18 16:06:18

标签: solr solrj solrcloud

我尝试使用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云节点都是

1 个答案:

答案 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

相关问题