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


Java CoreContainer.getZkController方法代碼示例

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


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

示例1: getAndPrepShardHandler

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
private ShardHandler getAndPrepShardHandler(SolrQueryRequest req, ResponseBuilder rb, ShardHandlerFactory shardHandlerFactory) {
  ShardHandler shardHandler = null;

  boolean isZkAware = false;
  CoreContainer cc = null;
  if (req.getCore() != null) {
    cc = req.getCore().getCoreContainer();
    isZkAware = cc.isZooKeeperAware();
  } 
  
  rb.isDistrib = req.getParams().getBool("distrib", isZkAware);
  if (!rb.isDistrib) {
    // for back compat, a shards param with URLs like localhost:8983/solr will mean that this
    // search is distributed.
    final String shards = req.getParams().get(ShardParams.SHARDS);
    rb.isDistrib = ((shards != null) && (shards.indexOf('/') > 0));
  }
  
  if (rb.isDistrib) {
    shardHandler = shardHandlerFactory.getShardHandler();
    shardHandler.prepDistributed(rb);
    if (!rb.isDistrib) {
      shardHandler = null; // request is not distributed after all and so the shard handler is not needed
    }
  }

  if(isZkAware) {
    ZkController zkController = cc.getZkController();
    NamedList<Object> headers = rb.rsp.getResponseHeader();
    if(headers != null) {
      headers.add("zkConnected", 
          zkController != null 
        ? !zkController.getZkClient().getConnectionManager().isLikelyExpired() 
        : false);
    }
    
  }

  return shardHandler;
}
 
開發者ID:sematext,項目名稱:solr-researcher,代碼行數:41,代碼來源:ReSearcherHandler.java

示例2: RecoveryStrategy

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
public RecoveryStrategy(CoreContainer cc, CoreDescriptor cd, RecoveryListener recoveryListener) {
  this.cc = cc;
  this.coreName = cd.getName();
  this.recoveryListener = recoveryListener;
  setName("RecoveryThread");
  zkController = cc.getZkController();
  zkStateReader = zkController.getZkStateReader();
  baseUrl = zkController.getBaseUrl();
  coreZkNodeName = cd.getCloudDescriptor().getCoreNodeName();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:11,代碼來源:RecoveryStrategy.java

示例3: initialize

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Override
public CoreContainer initialize() {
  CoreContainer container = new CoreContainer(new SolrResourceLoader(SolrResourceLoader.locateSolrHome())) {
    {
      hostPort = System.getProperty("hostPort");
      hostContext = "solr";
      defaultCoreName = CoreContainer.DEFAULT_DEFAULT_CORE_NAME;
      initShardHandler(null);
      initZooKeeper(System.getProperty("zkHost"), 10000);
    }
  };
  LogWatcher<?> logging = new JulWatcher("test");
  logging.registerListener(new ListenerConfig(), container);
  container.setLogging(logging);
  
  CoreDescriptor dcore = new CoreDescriptor(container, coreName, solrConfig.getResourceLoader().getInstanceDir());
  dcore.setConfigName(solrConfig.getResourceName());
  dcore.setSchemaName(indexSchema.getResourceName());
  SolrCore core = new SolrCore(coreName, dataDirectory, solrConfig, indexSchema, dcore);
  container.register(coreName, core, false);

  // TODO: we should be exercising the *same* core container initialization code, not equivalent code!
  if (container.getZkController() == null && core.getUpdateHandler().getUpdateLog() != null) {
    // always kick off recovery if we are in standalone mode.
    core.getUpdateHandler().getUpdateLog().recoverFromLog();
  }
  return container;
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:29,代碼來源:TestHarness.java

示例4: RecoveryStrategy

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
public RecoveryStrategy(CoreContainer cc, CoreDescriptor cd, RecoveryListener recoveryListener) {
  this.cc = cc;
  this.coreName = cd.getName();
  this.recoveryListener = recoveryListener;
  setName("RecoveryThread");
  zkController = cc.getZkController();
  zkStateReader = zkController.getZkStateReader();
  baseUrl = zkController.getBaseUrl();
  coreZkNodeName = zkController.getCoreNodeName(cd);
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:11,代碼來源:RecoveryStrategy.java

示例5: doGet

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Override
public void doGet(HttpServletRequest request,
                  HttpServletResponse response)
    throws ServletException,IOException {
  // This attribute is set by the SolrDispatchFilter
  CoreContainer cores = (CoreContainer) request.getAttribute("org.apache.solr.CoreContainer");
  if (cores == null) {
    throw new ServletException("Missing request attribute org.apache.solr.CoreContainer.");
  }
  
  final SolrParams params;
  try {
    params = SolrRequestParsers.DEFAULT.parse(null, request.getServletPath(), request).getParams();
  } catch (Exception e) {
    int code=500;
    if (e instanceof SolrException) {
      code = Math.min(599, Math.max(100, ((SolrException)e).code()));
    }
    response.sendError(code, e.toString());
    return;
  }

  String path = params.get("path");
  String addr = params.get("addr");

  if (addr != null && addr.length() == 0) {
    addr = null;
  }

  String detailS = params.get("detail");
  boolean detail = detailS != null && detailS.equals("true");

  String dumpS = params.get("dump");
  boolean dump = dumpS != null && dumpS.equals("true");

  response.setCharacterEncoding("UTF-8");
  response.setContentType("application/json");

  Writer out = new FastWriter(new OutputStreamWriter(response.getOutputStream(), StandardCharsets.UTF_8));

  ZKPrinter printer = new ZKPrinter(response, out, cores.getZkController(), addr);
  printer.detail = detail;
  printer.dump = dump;

  try {
    printer.print(path);
  } finally {
    printer.close();
  }
  
  out.flush();
}
 
開發者ID:europeana,項目名稱:search,代碼行數:53,代碼來源:ZookeeperInfoServlet.java

示例6: checkSharedFSFailoverReplaced

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
/**
 * See if coreNodeName has been taken over by another baseUrl and unload core
 * + throw exception if it has been.
 */
public static void checkSharedFSFailoverReplaced(CoreContainer cc, CoreDescriptor desc) {
  
  ZkController zkController = cc.getZkController();
  String thisCnn = zkController.getCoreNodeName(desc);
  String thisBaseUrl = zkController.getBaseUrl();
  
  log.debug("checkSharedFSFailoverReplaced running for coreNodeName={} baseUrl={}", thisCnn, thisBaseUrl);

  // if we see our core node name on a different base url, unload
  Map<String,Slice> slicesMap = zkController.getClusterState().getSlicesMap(desc.getCloudDescriptor().getCollectionName());
  
  if (slicesMap != null) {
    for (Slice slice : slicesMap.values()) {
      for (Replica replica : slice.getReplicas()) {
        
        String cnn = replica.getName();
        String baseUrl = replica.getStr(ZkStateReader.BASE_URL_PROP);
        log.debug("compare against coreNodeName={} baseUrl={}", cnn, baseUrl);
        
        if (thisCnn != null && thisCnn.equals(cnn)
            && !thisBaseUrl.equals(baseUrl)) {
          if (cc.getCoreNames().contains(desc.getName())) {
            cc.unload(desc.getName());
          }
          
          File instanceDir = new File(desc.getInstanceDir());
          try {
            FileUtils.deleteDirectory(instanceDir);
          } catch (IOException e) {
            SolrException.log(log, "Failed to delete instance dir for core:"
                + desc.getName() + " dir:" + instanceDir.getAbsolutePath());
          }
          log.error("", new SolrException(ErrorCode.SERVER_ERROR,
              "Will not load SolrCore " + desc.getName()
                  + " because it has been replaced due to failover."));
          throw new SolrException(ErrorCode.SERVER_ERROR,
              "Will not load SolrCore " + desc.getName()
                  + " because it has been replaced due to failover.");
        }
      }
    }
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:48,代碼來源:CloudUtil.java

示例7: testLeaderInitiatedRecoveryCRUD

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
/**
 * Tests handling of lir state znodes.
 */
protected void testLeaderInitiatedRecoveryCRUD() throws Exception {
  String testCollectionName = "c8n_crud_1x2";
  String shardId = "shard1";
  createCollection(testCollectionName, 1, 2, 1);
  cloudClient.setDefaultCollection(testCollectionName);

  Replica leader =
      cloudClient.getZkStateReader().getLeaderRetry(testCollectionName, shardId);
  JettySolrRunner leaderJetty = getJettyOnPort(getReplicaPort(leader));

  CoreContainer cores = ((SolrDispatchFilter)leaderJetty.getDispatchFilter().getFilter()).getCores();
  ZkController zkController = cores.getZkController();
  assertNotNull("ZkController is null", zkController);

  Replica notLeader =
      ensureAllReplicasAreActive(testCollectionName, shardId, 1, 2, maxWaitSecsToSeeAllActive).get(0);

  ZkCoreNodeProps replicaCoreNodeProps = new ZkCoreNodeProps(notLeader);
  String replicaUrl = replicaCoreNodeProps.getCoreUrl();

  assertTrue(!zkController.isReplicaInRecoveryHandling(replicaUrl));
  assertTrue(zkController.ensureReplicaInLeaderInitiatedRecovery(testCollectionName, shardId, replicaUrl, replicaCoreNodeProps, false));
  assertTrue(zkController.isReplicaInRecoveryHandling(replicaUrl));
  Map<String,Object> lirStateMap = zkController.getLeaderInitiatedRecoveryStateObject(testCollectionName, shardId, notLeader.getName());
  assertNotNull(lirStateMap);
  assertEquals(ZkStateReader.DOWN, lirStateMap.get("state"));
  zkController.removeReplicaFromLeaderInitiatedRecoveryHandling(replicaUrl);
  assertTrue(!zkController.isReplicaInRecoveryHandling(replicaUrl));

  // test old non-json format handling
  SolrZkClient zkClient = zkController.getZkClient();
  String znodePath = zkController.getLeaderInitiatedRecoveryZnodePath(testCollectionName, shardId, notLeader.getName());
  zkClient.setData(znodePath, "down".getBytes(StandardCharsets.UTF_8), true);
  lirStateMap = zkController.getLeaderInitiatedRecoveryStateObject(testCollectionName, shardId, notLeader.getName());
  assertNotNull(lirStateMap);
  assertEquals(ZkStateReader.DOWN, lirStateMap.get("state"));
  zkClient.delete(znodePath, -1, false);

  // try to clean up
  try {
    CollectionAdminRequest req = new CollectionAdminRequest.Delete();
    req.setCollectionName(testCollectionName);
    req.process(cloudClient);
  } catch (Exception e) {
    // don't fail the test
    log.warn("Could not delete collection {} after test completed", testCollectionName);
  }
}
 
開發者ID:europeana,項目名稱:search,代碼行數:52,代碼來源:HttpPartitionTest.java

示例8: doGet

import org.apache.solr.core.CoreContainer; //導入方法依賴的package包/類
@Override
public void doGet(HttpServletRequest request,
                  HttpServletResponse response)
    throws ServletException,IOException {
  // This attribute is set by the SolrDispatchFilter
  CoreContainer cores = (CoreContainer) request.getAttribute("org.apache.solr.CoreContainer");
  if (cores == null) {
    throw new ServletException("Missing request attribute org.apache.solr.CoreContainer.");
  }
  
  final SolrParams params;
  try {
    params = SolrRequestParsers.DEFAULT.parse(null, request.getServletPath(), request).getParams();
  } catch (Exception e) {
    int code=500;
    if (e instanceof SolrException) {
      code = Math.min(599, Math.max(100, ((SolrException)e).code()));
    }
    response.sendError(code, e.toString());
    return;
  }

  String path = params.get("path");
  String addr = params.get("addr");

  if (addr != null && addr.length() == 0) {
    addr = null;
  }

  String detailS = params.get("detail");
  boolean detail = detailS != null && detailS.equals("true");

  String dumpS = params.get("dump");
  boolean dump = dumpS != null && dumpS.equals("true");

  response.setCharacterEncoding("UTF-8");
  response.setContentType("application/json");

  Writer out = new FastWriter(new OutputStreamWriter(response.getOutputStream(), IOUtils.CHARSET_UTF_8));

  ZKPrinter printer = new ZKPrinter(response, out, cores.getZkController(), addr);
  printer.detail = detail;
  printer.dump = dump;

  try {
    printer.print(path);
  } finally {
    printer.close();
  }
  
  out.flush();
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:53,代碼來源:ZookeeperInfoServlet.java


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