簡體   English   中英

Solr觸發器從Java代碼優化並檢查進度

[英]Solr Trigger Optimize And Check Progress From Java Code

從本主題開始 ,有兩種方法可以從Java代碼觸發solr優化。
發送http請求或使用solrj api。
但是如何檢查進度呢?
例如,一個以百分比形式返回優化進度的API
或諸如RUNNING / COMPLETED / FAILED之類的字符串。
有這樣的API嗎?

是的,solrj api中的optimize()是一種同步方法。
這是我用來監視優化進度的內容。

CloudSolrClient client = null;
    try {
        client = new CloudSolrClient(zkClientUrl);
        client.setDefaultCollection(collectionName);
        m_logger.info("Explicit optimize of collection " + collectionName);
        long optimizeStart = System.currentTimeMillis();
        UpdateResponse optimizeResponse = client.optimize();

        for (Object object : optimizeResponse.getResponse()) {
            m_logger.info("Solr optimizeResponse" + object.toString());
        }
        if (optimizeResponse != null) {
            m_logger.info(String.format(
                    " Elapsed Time(in ms) - %d, QTime (in ms) - %d",
                    optimizeResponse.getElapsedTime(),
                    optimizeResponse.getQTime()));
        }
        m_logger.info(String.format(
                "Time spent on Optimizing a collection %s :"
                        + (System.currentTimeMillis() - optimizeStart)
                        / 1000 + " seconds", collectionName));
    } catch (Exception e) {
        m_logger.error("Failed during explicit optimize on collection "
                + collectionName, e);
    } finally {
        if (client != null) {
            try {
                client.close();
            } catch (IOException e) {
                throw new RuntimeException(
                        "Failed to close CloudSolrClient connection.", e);
            }
            client = null;
        }
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM