当前位置: 首页>>代码示例>>Java>>正文


Java ServerName.getHostAndPort方法代码示例

本文整理汇总了Java中org.apache.hadoop.hbase.ServerName.getHostAndPort方法的典型用法代码示例。如果您正苦于以下问题:Java ServerName.getHostAndPort方法的具体用法?Java ServerName.getHostAndPort怎么用?Java ServerName.getHostAndPort使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.hadoop.hbase.ServerName的用法示例。


在下文中一共展示了ServerName.getHostAndPort方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: isServerDeadAndNotProcessed

import org.apache.hadoop.hbase.ServerName; //导入方法依赖的package包/类
synchronized boolean isServerDeadAndNotProcessed(ServerName server) {
  if (server == null) return false;
  if (serverManager.isServerOnline(server)) {
    String hostAndPort = server.getHostAndPort();
    long startCode = server.getStartcode();
    Long deadCode = deadServers.get(hostAndPort);
    if (deadCode == null || startCode > deadCode.longValue()) {
      if (serverManager.isServerReachable(server)) {
        return false;
      }
      // The size of deadServers won't grow unbounded.
      deadServers.put(hostAndPort, Long.valueOf(startCode));
    }
    // Watch out! If the server is not dead, the region could
    // remain unassigned. That's why ServerManager#isServerReachable
    // should use some retry.
    //
    // We cache this info since it is very unlikely for that
    // instance to come back up later on. We don't want to expire
    // the server since we prefer to let it die naturally.
    LOG.warn("Couldn't reach online server " + server);
  }
  // Now, we know it's dead. Check if it's processed
  return !processedServers.containsKey(server);
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:26,代码来源:RegionStates.java

示例2: toString

import org.apache.hadoop.hbase.ServerName; //导入方法依赖的package包/类
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="SBSC_USE_STRINGBUFFER_CONCATENATION",
    justification="Not important but should be fixed")
@Override
public String toString() {
  String desc = "Cluster{" +
      "servers=[";
      for(ServerName sn:servers) {
         desc += sn.getHostAndPort() + ", ";
      }
      desc +=
      ", serverIndicesSortedByRegionCount="+
      Arrays.toString(serverIndicesSortedByRegionCount) +
      ", regionsPerServer=[";

      for (int[]r:regionsPerServer) {
        desc += Arrays.toString(r);
      }
      desc += "]" +
      ", numMaxRegionsPerTable=" +
      Arrays.toString(numMaxRegionsPerTable) +
      ", numRegions=" +
      numRegions +
      ", numServers=" +
      numServers +
      ", numTables=" +
      numTables +
      ", numMovedRegions=" +
      numMovedRegions +
      '}';
  return desc;
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:32,代码来源:BaseLoadBalancer.java

示例3: countMetaRegions

import org.apache.hadoop.hbase.ServerName; //导入方法依赖的package包/类
private static int countMetaRegions(final HMaster master, final TableName tableName)
    throws IOException {
  final AtomicInteger actualRegCount = new AtomicInteger(0);
  final MetaScannerVisitor visitor = new MetaScannerVisitorBase() {
    @Override
    public boolean processRow(Result rowResult) throws IOException {
      RegionLocations list = MetaTableAccessor.getRegionLocations(rowResult);
      if (list == null) {
        LOG.warn("No serialized HRegionInfo in " + rowResult);
        return true;
      }
      HRegionLocation l = list.getRegionLocation();
      if (l == null) {
        return true;
      }
      if (!l.getRegionInfo().getTable().equals(tableName)) {
        return false;
      }
      if (l.getRegionInfo().isOffline() || l.getRegionInfo().isSplit()) return true;
      HRegionLocation[] locations = list.getRegionLocations();
      for (HRegionLocation location : locations) {
        if (location == null) continue;
        ServerName serverName = location.getServerName();
        // Make sure that regions are assigned to server
        if (serverName != null && serverName.getHostAndPort() != null) {
          actualRegCount.incrementAndGet();
        }
      }
      return true;
    }
  };
  MetaScanner.metaScan(master.getConnection(), visitor, tableName);
  return actualRegCount.get();
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:35,代码来源:MasterProcedureTestingUtility.java

示例4: waitForAllRegionsOnline

import org.apache.hadoop.hbase.ServerName; //导入方法依赖的package包/类
private void waitForAllRegionsOnline(final long deadlineTs)
    throws IOException, TimeoutException {
  final AtomicInteger actualRegCount = new AtomicInteger(0);
  final MetaScannerVisitor visitor = new MetaScannerVisitorBase() {
    @Override
    public boolean processRow(Result rowResult) throws IOException {
      RegionLocations list = MetaTableAccessor.getRegionLocations(rowResult);
      if (list == null) {
        LOG.warn("No serialized HRegionInfo in " + rowResult);
        return true;
      }
      HRegionLocation l = list.getRegionLocation();
      if (l == null) {
        return true;
      }
      if (!l.getRegionInfo().getTable().equals(desc.getTableName())) {
        return false;
      }
      if (l.getRegionInfo().isOffline() || l.getRegionInfo().isSplit()) return true;
      HRegionLocation[] locations = list.getRegionLocations();
      for (HRegionLocation location : locations) {
        if (location == null) continue;
        ServerName serverName = location.getServerName();
        // Make sure that regions are assigned to server
        if (serverName != null && serverName.getHostAndPort() != null) {
          actualRegCount.incrementAndGet();
        }
      }
      return true;
    }
  };

  int tries = 0;
  IOException serverEx = null;
  int numRegs = (splitKeys == null ? 1 : splitKeys.length + 1) * desc.getRegionReplication();
  while (EnvironmentEdgeManager.currentTime() < deadlineTs) {
    actualRegCount.set(0);
    MetaScanner.metaScan(getAdmin().getConnection(), visitor, desc.getTableName());
    if (actualRegCount.get() == numRegs) {
      // all the regions are online
      return;
    }

    try {
      Thread.sleep(getAdmin().getPauseTime(tries++));
    } catch (InterruptedException e) {
      throw new InterruptedIOException("Interrupted when opening" +
        " regions; " + actualRegCount.get() + " of " + numRegs +
        " regions processed so far");
    }
  }
  throw new TimeoutException("Only " + actualRegCount.get() +
          " of " + numRegs + " regions are online; retries exhausted.");
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:55,代码来源:HBaseAdmin.java


注:本文中的org.apache.hadoop.hbase.ServerName.getHostAndPort方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。