當前位置: 首頁>>代碼示例>>Java>>正文


Java CoreContainer.getCore方法代碼示例

本文整理匯總了Java中org.apache.solr.core.CoreContainer.getCore方法的典型用法代碼示例。如果您正苦於以下問題:Java CoreContainer.getCore方法的具體用法?Java CoreContainer.getCore怎麽用?Java CoreContainer.getCore使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.solr.core.CoreContainer的用法示例。


在下文中一共展示了CoreContainer.getCore方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: checkProps

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
private SolrCore checkProps(CoreContainer cores, String path,
    ZkNodeProps zkProps) {
  String corename;
  SolrCore core = null;
  if (cores.getZkController().getNodeName().equals(zkProps.getStr(ZkStateReader.NODE_NAME_PROP))) {
    corename = zkProps.getStr(ZkStateReader.CORE_NAME_PROP);
    core = cores.getCore(corename);
  }
  return core;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:11,代碼來源:SolrDispatchFilter.java

示例2: testMergeIndexesCoreAdminHandler

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Test
public void testMergeIndexesCoreAdminHandler() throws Exception {
  final File workDir = createTempDir();

  final CoreContainer cores = h.getCoreContainer();

  final CoreAdminHandler admin = new CoreAdminHandler(cores);

  try (SolrCore core = cores.getCore("collection1")) {
    FailingDirectoryFactory dirFactory = (FailingDirectoryFactory)core.getDirectoryFactory();

    try {
      dirFactory.fail = true;
      ignoreException(FAILING_MSG);

      SolrQueryResponse resp = new SolrQueryResponse();
      admin.handleRequestBody
          (req(CoreAdminParams.ACTION,
              CoreAdminParams.CoreAdminAction.MERGEINDEXES.toString(),
              CoreAdminParams.CORE, "collection1",
              CoreAdminParams.INDEX_DIR, workDir.getAbsolutePath()),
              resp);
      fail("exception expected");
    } catch (FailingDirectoryFactory.FailingDirectoryFactoryException e) {
      // expected if error handling properly
    } finally {
      unIgnoreException(FAILING_MSG);
    }
    dirFactory.fail = false;
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:32,代碼來源:CoreMergeIndexesAdminHandlerTest.java

示例3: testOptimizeDiffSchemas

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Test
public void testOptimizeDiffSchemas() throws Exception {
  // load up a core (why not put it on disk?)
  CoreContainer cc = init();
  try (SolrCore changed = cc.getCore("changed")) {

    // add some documents
    addDoc(changed, "id", "1", "which", "15", "text", "some stuff with which");
    addDoc(changed, "id", "2", "which", "15", "text", "some stuff with which");
    addDoc(changed, "id", "3", "which", "15", "text", "some stuff with which");
    addDoc(changed, "id", "4", "which", "15", "text", "some stuff with which");
    SolrQueryRequest req = new LocalSolrQueryRequest(changed, new NamedList<>());
    changed.getUpdateHandler().commit(new CommitUpdateCommand(req, false));

    // write the new schema out and make it current
    FileUtils.writeStringToFile(schemaFile, withoutWhich, Charsets.UTF_8.toString());

    IndexSchema iSchema = IndexSchemaFactory.buildIndexSchema("schema.xml", changed.getSolrConfig());
    changed.setLatestSchema(iSchema);

    addDoc(changed, "id", "1", "text", "some stuff without which");
    addDoc(changed, "id", "5", "text", "some stuff without which");

    changed.getUpdateHandler().commit(new CommitUpdateCommand(req, false));
    changed.getUpdateHandler().commit(new CommitUpdateCommand(req, true));
  } finally {
    if (cc != null) cc.shutdown();
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:30,代碼來源:ChangedSchemaMergeTest.java

示例4: getCoreStatus

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
protected NamedList<Object> getCoreStatus(CoreContainer cores, String cname, boolean isIndexInfoNeeded) throws IOException {
  NamedList<Object> info = new SimpleOrderedMap<Object>();
  SolrCore core = cores.getCore(cname);
  if (core != null) {
    try {
      info.add("name", core.getName());
      info.add("isDefaultCore", core.getName().equals(cores.getDefaultCoreName()));
      info.add("instanceDir", normalizePath(core.getResourceLoader().getInstanceDir()));
      info.add("dataDir", normalizePath(core.getDataDir()));
      info.add("config", core.getConfigResource());
      info.add("schema", core.getSchemaResource());
      info.add("startTime", new Date(core.getStartTime()));
      info.add("uptime", System.currentTimeMillis() - core.getStartTime());
      if (isIndexInfoNeeded) {
        RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
        try {
          SimpleOrderedMap<Object> indexInfo = LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader());
          long size = getIndexSize(core);
          indexInfo.add("sizeInBytes", size);
          indexInfo.add("size", NumberUtils.readableSize(size));
          info.add("index", indexInfo);
        } finally {
          searcher.decref();
        }
      }
    } finally {
      core.close();
    }
  }
  return info;
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:32,代碼來源:CoreAdminHandler.java

示例5: getCoreStatus

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
protected NamedList<Object> getCoreStatus(CoreContainer cores, String cname, boolean isIndexInfoNeeded) throws IOException {
	NamedList<Object> info = new SimpleOrderedMap<Object>();
	SolrCore core = cores.getCore(cname);
	if(core != null) {
		try {
			info.add("name", core.getName());
			info.add("isDefaultCore", core.getName().equals(cores.getDefaultCoreName()));
			info.add("instanceDir", normalizePath(core.getResourceLoader().getInstanceDir()));
			info.add("dataDir", normalizePath(core.getDataDir()));
			info.add("config", core.getConfigResource());
			info.add("schema", core.getSchemaResource());
			info.add("startTime", new Date(core.getStartTime()));
			info.add("uptime", System.currentTimeMillis() - core.getStartTime());
			if(isIndexInfoNeeded) {
				RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
				try {
					SimpleOrderedMap<Object> indexInfo = LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader());
					long size = getIndexSize(core);
					indexInfo.add("sizeInBytes", size);
					indexInfo.add("size", NumberUtils.readableSize(size));
					info.add("index", indexInfo);
				} finally {
					searcher.decref();
				}
			}
		} finally {
			core.close();
		}
	}
	return info;
}
 
開發者ID:netboynb,項目名稱:search-core,代碼行數:32,代碼來源:CoreAdminHandler.java

示例6: createParser

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Override
public QParser createParser(String qstr, SolrParams localParams, SolrParams params, SolrQueryRequest req) {
  return new QParser(qstr, localParams, params, req) {
    @Override
    public Query parse() throws SyntaxError {
      String fromField = getParam("from");
      String fromIndex = getParam("fromIndex");
      String toField = getParam("to");
      String v = localParams.get("v");
      Query fromQuery;
      long fromCoreOpenTime = 0;

      if (fromIndex != null && !fromIndex.equals(req.getCore().getCoreDescriptor().getName()) ) {
        CoreContainer container = req.getCore().getCoreDescriptor().getCoreContainer();

        final SolrCore fromCore = container.getCore(fromIndex);
        RefCounted<SolrIndexSearcher> fromHolder = null;

        if (fromCore == null) {
          throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "Cross-core join: no such core " + fromIndex);
        }

        LocalSolrQueryRequest otherReq = new LocalSolrQueryRequest(fromCore, params);
        try {
          QParser parser = QParser.getParser(v, "lucene", otherReq);
          fromQuery = parser.getQuery();
          fromHolder = fromCore.getRegisteredSearcher();
          if (fromHolder != null) fromCoreOpenTime = fromHolder.get().getOpenTime();
        } finally {
          otherReq.close();
          fromCore.close();
          if (fromHolder != null) fromHolder.decref();
        }
      } else {
        QParser fromQueryParser = subQuery(v, null);
        fromQuery = fromQueryParser.getQuery();
      }

      JoinQuery jq = new JoinQuery(fromField, toField, fromIndex, fromQuery);
      jq.fromCoreOpenTime = fromCoreOpenTime;
      return jq;
    }
  };
}
 
開發者ID:europeana,項目名稱:search,代碼行數:45,代碼來源:JoinQParserPlugin.java

示例7: JoinQueryWeight

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
public JoinQueryWeight(SolrIndexSearcher searcher) {
  this.fromSearcher = searcher;
  SolrRequestInfo info = SolrRequestInfo.getRequestInfo();
  if (info != null) {
    rb = info.getResponseBuilder();
  }

  if (fromIndex == null) {
    this.fromSearcher = searcher;
  } else {
    if (info == null) {
      throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "Cross-core join must have SolrRequestInfo");
    }

    CoreContainer container = searcher.getCore().getCoreDescriptor().getCoreContainer();
    final SolrCore fromCore = container.getCore(fromIndex);

    if (fromCore == null) {
      throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "Cross-core join: no such core " + fromIndex);
    }

    if (info.getReq().getCore() == fromCore) {
      // if this is the same core, use the searcher passed in... otherwise we could be warming and
      // get an older searcher from the core.
      fromSearcher = searcher;
    } else {
      // This could block if there is a static warming query with a join in it, and if useColdSearcher is true.
      // Deadlock could result if two cores both had useColdSearcher and had joins that used eachother.
      // This would be very predictable though (should happen every time if misconfigured)
      fromRef = fromCore.getSearcher(false, true, null);

      // be careful not to do anything with this searcher that requires the thread local
      // SolrRequestInfo in a manner that requires the core in the request to match
      fromSearcher = fromRef.get();
    }

    if (fromRef != null) {
      final RefCounted<SolrIndexSearcher> ref = fromRef;
      info.addCloseHook(new Closeable() {
        @Override
        public void close() {
          ref.decref();
        }
      });
    }

    info.addCloseHook(new Closeable() {
      @Override
      public void close() {
        fromCore.close();
      }
    });

  }
  this.toSearcher = searcher;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:57,代碼來源:JoinQParserPlugin.java

示例8: getCoreStatus

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
/**
 * Returns the core status for a particular core.
 * @param cores - the enclosing core container
 * @param cname - the core to return
 * @param isIndexInfoNeeded - add what may be expensive index information. NOT returned if the core is not loaded
 * @return - a named list of key/value pairs from the core.
 * @throws IOException - LukeRequestHandler can throw an I/O exception
 */
protected NamedList<Object> getCoreStatus(CoreContainer cores, String cname, boolean isIndexInfoNeeded)  throws IOException {
  NamedList<Object> info = new SimpleOrderedMap<>();

  if (!cores.isLoaded(cname)) { // Lazily-loaded core, fill in what we can.
    // It would be a real mistake to load the cores just to get the status
    CoreDescriptor desc = cores.getUnloadedCoreDescriptor(cname);
    if (desc != null) {
      info.add("name", desc.getName());
      info.add("isDefaultCore", desc.getName().equals(cores.getDefaultCoreName()));
      info.add("instanceDir", desc.getInstanceDir());
      // None of the following are guaranteed to be present in a not-yet-loaded core.
      String tmp = desc.getDataDir();
      if (StringUtils.isNotBlank(tmp)) info.add("dataDir", tmp);
      tmp = desc.getConfigName();
      if (StringUtils.isNotBlank(tmp)) info.add("config", tmp);
      tmp = desc.getSchemaName();
      if (StringUtils.isNotBlank(tmp)) info.add("schema", tmp);
      info.add("isLoaded", "false");
    }
  } else {
    try (SolrCore core = cores.getCore(cname)) {
      if (core != null) {
        info.add("name", core.getName());
        info.add("isDefaultCore", core.getName().equals(cores.getDefaultCoreName()));
        info.add("instanceDir", normalizePath(core.getResourceLoader().getInstanceDir()));
        info.add("dataDir", normalizePath(core.getDataDir()));
        info.add("config", core.getConfigResource());
        info.add("schema", core.getSchemaResource());
        info.add("startTime", new Date(core.getStartTime()));
        info.add("uptime", System.currentTimeMillis() - core.getStartTime());
        if (isIndexInfoNeeded) {
          RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
          try {
            SimpleOrderedMap<Object> indexInfo = LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader());
            long size = getIndexSize(core);
            indexInfo.add("sizeInBytes", size);
            indexInfo.add("size", NumberUtils.readableSize(size));
            info.add("index", indexInfo);
          } finally {
            searcher.decref();
          }
        }
      }
    }
  }
  return info;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:56,代碼來源:CoreAdminHandler.java

示例9: getCoreStatus

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
/**
 * Returns the core status for a particular core.
 * @param cores - the enclosing core container
 * @param cname - the core to return
 * @param isIndexInfoNeeded - add what may be expensive index information. NOT returned if the core is not loaded
 * @return - a named list of key/value pairs from the core.
 * @throws IOException - LukeRequestHandler can throw an I/O exception
 */
protected NamedList<Object> getCoreStatus(CoreContainer cores, String cname, boolean isIndexInfoNeeded)  throws IOException {
  NamedList<Object> info = new SimpleOrderedMap<Object>();

  if (!cores.isLoaded(cname)) { // Lazily-loaded core, fill in what we can.
    // It would be a real mistake to load the cores just to get the status
    CoreDescriptor desc = cores.getUnloadedCoreDescriptor(cname);
    if (desc != null) {
      info.add("name", desc.getName());
      info.add("isDefaultCore", desc.getName().equals(cores.getDefaultCoreName()));
      info.add("instanceDir", desc.getInstanceDir());
      // None of the following are guaranteed to be present in a not-yet-loaded core.
      String tmp = desc.getDataDir();
      if (StringUtils.isNotBlank(tmp)) info.add("dataDir", tmp);
      tmp = desc.getConfigName();
      if (StringUtils.isNotBlank(tmp)) info.add("config", tmp);
      tmp = desc.getSchemaName();
      if (StringUtils.isNotBlank(tmp)) info.add("schema", tmp);
      info.add("isLoaded", "false");
    }
  } else {
    SolrCore core = cores.getCore(cname);
    if (core != null) {
      try {
        info.add("name", core.getName());
        info.add("isDefaultCore", core.getName().equals(cores.getDefaultCoreName()));
        info.add("instanceDir", normalizePath(core.getResourceLoader().getInstanceDir()));
        info.add("dataDir", normalizePath(core.getDataDir()));
        info.add("config", core.getConfigResource());
        info.add("schema", core.getSchemaResource());
        info.add("startTime", new Date(core.getStartTime()));
        info.add("uptime", System.currentTimeMillis() - core.getStartTime());
        if (isIndexInfoNeeded) {
          RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
          try {
            SimpleOrderedMap<Object> indexInfo = LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader());
            long size = getIndexSize(core);
            indexInfo.add("sizeInBytes", size);
            indexInfo.add("size", NumberUtils.readableSize(size));
            info.add("index", indexInfo);
          } finally {
            searcher.decref();
          }
        }
      } finally {
        core.close();
      }
    }
  }
  return info;
}
 
開發者ID:yintaoxue,項目名稱:read-open-source-code,代碼行數:59,代碼來源:CoreAdminHandler.java


注:本文中的org.apache.solr.core.CoreContainer.getCore方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。