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


Java ServerName.isSameHostnameAndPort方法代碼示例

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


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

示例1: getFavoredServerPosition

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
/**
 * Return the position of the server in the favoredNodes list. Assumes the
 * favoredNodes list is of size 3.
 * @param favoredNodes
 * @param server
 * @return position
 */
public static Position getFavoredServerPosition(
    List<ServerName> favoredNodes, ServerName server) {
  if (favoredNodes == null || server == null ||
      favoredNodes.size() != FavoredNodeAssignmentHelper.FAVORED_NODES_NUM) {
    return null;
  }
  for (Position p : Position.values()) {
    if (ServerName.isSameHostnameAndPort(favoredNodes.get(p.ordinal()),server)) {
      return p;
    }
  }
  return null;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:FavoredNodesPlan.java

示例2: availableServersContains

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
private ServerName availableServersContains(List<ServerName> servers, ServerName favoredNode) {
  for (ServerName server : servers) {
    if (ServerName.isSameHostnameAndPort(favoredNode, server)) {
      return server;
    }
  }
  return null;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:9,代碼來源:FavoredNodeLoadBalancer.java

示例3: findServerWithSameHostnamePortWithLock

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
/**
 * Assumes onlineServers is locked.
 * @return ServerName with matching hostname and port.
 */
private ServerName findServerWithSameHostnamePortWithLock(
    final ServerName serverName) {
  for (ServerName sn: this.onlineServers.keySet()) {
    if (ServerName.isSameHostnameAndPort(serverName, sn)) return sn;
  }
  return null;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:12,代碼來源:ServerManager.java

示例4: cleanPreviousInstance

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
/**
 * A dead server that comes back alive has a different start code. The new start code should be
 *  greater than the old one, but we don't take this into account in this method.
 *
 * @param newServerName Servername as either <code>host:port</code> or
 *                      <code>host,port,startcode</code>.
 * @return true if this server was dead before and coming back alive again
 */
public synchronized boolean cleanPreviousInstance(final ServerName newServerName) {
  Iterator<ServerName> it = deadServers.keySet().iterator();
  while (it.hasNext()) {
    ServerName sn = it.next();
    if (ServerName.isSameHostnameAndPort(sn, newServerName)) {
      it.remove();
      return true;
    }
  }

  return false;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:DeadServer.java

示例5: cleanAllPreviousInstances

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
public synchronized void cleanAllPreviousInstances(final ServerName newServerName) {
  Iterator<ServerName> it = deadServers.keySet().iterator();
  while (it.hasNext()) {
    ServerName sn = it.next();
    if (ServerName.isSameHostnameAndPort(sn, newServerName)) {
      it.remove();
    }
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:10,代碼來源:DeadServer.java

示例6: addToMovedRegions

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
protected void addToMovedRegions(String encodedName, ServerName destination, long closeSeqNum) {
  if (ServerName.isSameHostnameAndPort(destination, this.getServerName())) {
    LOG.warn("Not adding moved region record: " + encodedName + " to self.");
    return;
  }
  LOG.info("Adding moved region record: " + encodedName + " to " + destination + " as of "
      + closeSeqNum);
  movedRegions.put(encodedName, new MovedRegionInfo(destination, closeSeqNum));
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:10,代碼來源:HRegionServer.java

示例7: removeMatchingServers

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
private List<ServerName> removeMatchingServers(ServerName serverWithoutStartCode,
    List<ServerName> servers) {
  List<ServerName> serversToRemove = new ArrayList<ServerName>();
  for (ServerName s : servers) {
    if (ServerName.isSameHostnameAndPort(s, serverWithoutStartCode)) {
      serversToRemove.add(s);
    }
  }
  servers.removeAll(serversToRemove);
  return serversToRemove;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:12,代碼來源:TestRegionPlacement2.java

示例8: testAssignOfflinedRegionBySSH

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
/**
 * Test offlined region is assigned by SSH
 */
@Test (timeout=60000)
public void testAssignOfflinedRegionBySSH() throws Exception {
  String table = "testAssignOfflinedRegionBySSH";
  MiniHBaseCluster cluster = TEST_UTIL.getHBaseCluster();
  MyMaster master = null;
  try {
    HTableDescriptor desc = new HTableDescriptor(TableName.valueOf(table));
    desc.addFamily(new HColumnDescriptor(FAMILY));
    admin.createTable(desc);

    Table meta = new HTable(conf, TableName.META_TABLE_NAME);
    HRegionInfo hri = new HRegionInfo(
      desc.getTableName(), Bytes.toBytes("A"), Bytes.toBytes("Z"));
    MetaTableAccessor.addRegionToMeta(meta, hri);

    // Assign the region
    master = (MyMaster)cluster.getMaster();
    master.assignRegion(hri);

    AssignmentManager am = master.getAssignmentManager();
    RegionStates regionStates = am.getRegionStates();
    ServerName metaServer = regionStates.getRegionServerOfRegion(
      HRegionInfo.FIRST_META_REGIONINFO);
    ServerName oldServerName = null;
    while (true) {
      assertTrue(am.waitForAssignment(hri));
      RegionState state = regionStates.getRegionState(hri);
      oldServerName = state.getServerName();
      if (!ServerName.isSameHostnameAndPort(oldServerName, metaServer)) {
        // Mark the hosting server aborted, but don't actually kill it.
        // It doesn't have meta on it.
        MyRegionServer.abortedServer = oldServerName;
        break;
      }
      int i = cluster.getServerWithMeta();
      HRegionServer rs = cluster.getRegionServer(i == 0 ? 1 : 0);
      oldServerName = rs.getServerName();
      master.move(hri.getEncodedNameAsBytes(),
        Bytes.toBytes(oldServerName.getServerName()));
    }

    // Make sure the region is assigned on the dead server
    assertTrue(regionStates.isRegionOnline(hri));
    assertEquals(oldServerName, regionStates.getRegionServerOfRegion(hri));

    // Kill the hosting server, which doesn't have meta on it.
    cluster.killRegionServer(oldServerName);
    cluster.waitForRegionServerToStop(oldServerName, -1);

    ServerManager serverManager = master.getServerManager();
    while (!serverManager.isServerDead(oldServerName)
        || serverManager.getDeadServers().areDeadServersInProgress()) {
      Thread.sleep(100);
    }

    // Let's check if it's assigned after it's out of transition.
    // no need to assign it manually, SSH should do it
    am.waitOnRegionToClearRegionsInTransition(hri);
    assertTrue(am.waitForAssignment(hri));

    ServerName serverName = master.getAssignmentManager().
      getRegionStates().getRegionServerOfRegion(hri);
    TEST_UTIL.assertRegionOnlyOnServer(hri, serverName, 200);
  } finally {
    MyRegionServer.abortedServer = null;
    TEST_UTIL.deleteTable(Bytes.toBytes(table));
    cluster.startRegionServer();
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:73,代碼來源:TestAssignmentManagerOnCluster.java

示例9: testAssignDisabledRegionBySSH

import org.apache.hadoop.hbase.ServerName; //導入方法依賴的package包/類
/**
 * Test disabled region is ignored by SSH
 */
@Test (timeout=60000)
public void testAssignDisabledRegionBySSH() throws Exception {
  String table = "testAssignDisabledRegionBySSH";
  MiniHBaseCluster cluster = TEST_UTIL.getHBaseCluster();
  MyMaster master = null;
  try {
    HTableDescriptor desc = new HTableDescriptor(TableName.valueOf(table));
    desc.addFamily(new HColumnDescriptor(FAMILY));
    admin.createTable(desc);

    Table meta = new HTable(conf, TableName.META_TABLE_NAME);
    HRegionInfo hri = new HRegionInfo(
      desc.getTableName(), Bytes.toBytes("A"), Bytes.toBytes("Z"));
    MetaTableAccessor.addRegionToMeta(meta, hri);

    // Assign the region
    master = (MyMaster)cluster.getMaster();
    master.assignRegion(hri);

    AssignmentManager am = master.getAssignmentManager();
    RegionStates regionStates = am.getRegionStates();
    ServerName metaServer = regionStates.getRegionServerOfRegion(
      HRegionInfo.FIRST_META_REGIONINFO);
    ServerName oldServerName = null;
    while (true) {
      assertTrue(am.waitForAssignment(hri));
      RegionState state = regionStates.getRegionState(hri);
      oldServerName = state.getServerName();
      if (!ServerName.isSameHostnameAndPort(oldServerName, metaServer)) {
        // Mark the hosting server aborted, but don't actually kill it.
        // It doesn't have meta on it.
        MyRegionServer.abortedServer = oldServerName;
        break;
      }
      int i = cluster.getServerWithMeta();
      HRegionServer rs = cluster.getRegionServer(i == 0 ? 1 : 0);
      oldServerName = rs.getServerName();
      master.move(hri.getEncodedNameAsBytes(),
        Bytes.toBytes(oldServerName.getServerName()));
    }

    // Make sure the region is assigned on the dead server
    assertTrue(regionStates.isRegionOnline(hri));
    assertEquals(oldServerName, regionStates.getRegionServerOfRegion(hri));

    // Disable the table now.
    master.disableTable(hri.getTable(), HConstants.NO_NONCE, HConstants.NO_NONCE);

    // Kill the hosting server, which doesn't have meta on it.
    cluster.killRegionServer(oldServerName);
    cluster.waitForRegionServerToStop(oldServerName, -1);

    ServerManager serverManager = master.getServerManager();
    while (!serverManager.isServerDead(oldServerName)
        || serverManager.getDeadServers().areDeadServersInProgress()) {
      Thread.sleep(100);
    }

    // Wait till no more RIT, the region should be offline.
    am.waitUntilNoRegionsInTransition(60000);
    assertTrue(regionStates.isRegionOffline(hri));
  } finally {
    MyRegionServer.abortedServer = null;
    TEST_UTIL.deleteTable(Bytes.toBytes(table));
    cluster.startRegionServer();
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:71,代碼來源:TestAssignmentManagerOnCluster.java


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