Как я могу получить список всех ядер на сервере Solr, используя SolrJ - PullRequest
14 голосов
/ 12 июля 2011

Мы используем Solr для наших поисков и разделяем данные по нескольким ядрам. У нас есть одно ядро ​​в неделю данных, поэтому мы динамически создаем и удаляем ядра каждую неделю.

Как я могу запросить у сервера solr список всех его ядер? JavaDoc говорит, что я могу использовать coreAdminHandler.getCoreContainer().getCoreNames(), но я не уверен, как создать объект coreAdminHandler.

Ответы [ 3 ]

20 голосов
/ 12 июля 2011

Запрос на http://localhost:8983/solr/admin/cores?action=STATUS (конечно, замените ваш собственный хост / порт) вернет все ядра.

19 голосов
/ 06 апреля 2012

Используя SolrJ , как вы и просили, вот как я это сделал:

// Solr server instance
CommonsHttpSolrServer solrServer = ...;

// Request core list
CoreAdminRequest request = new CoreAdminRequest();
request.setAction(CoreAdminAction.STATUS);
CoreAdminResponse cores = request.process(solrServer);

// List of the cores
List<String> coreList = new ArrayList<String>();
for (int i = 0; i < cores.getCoreStatus().size(); i++) {
    coreList.add(cores.getCoreStatus().getName(i));
}
1 голос
/ 17 сентября 2016

Просто добавление обновления в приведенный выше пример кода, так как несколько битов устарели после Solr 4. Следующий код работает на Solr 6.1.0.

package <...>.<...>.<...>;    

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;    

import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.request.CoreAdminRequest;
import org.apache.solr.client.solrj.response.CoreAdminResponse;
import org.apache.solr.common.params.CoreAdminParams.CoreAdminAction;    

public class GetCores {
    static String SOLR_URL = "http://...:8983/solr/";    

    public static void getCores() {
        System.out.println("Building Solr server instance");
        HttpSolrClient solrClient=new HttpSolrClient.Builder(SOLR_URL).build();    

        System.out.println("Requesting core list"); 
        CoreAdminRequest request = new CoreAdminRequest();
        request.setAction(CoreAdminAction.STATUS);
        CoreAdminResponse cores=null;

        try {
            cores = request.process(solrClient);
        } catch (SolrServerException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

        System.out.println(" Listing cores");
        List<String> coreList = new ArrayList<String>();
        for (int i = 0; i < cores.getCoreStatus().size(); i++) {
            coreList.add(cores.getCoreStatus().getName(i));
        }

        System.out.println(coreList.get(0)+" is the first core");    
    }       
}
...