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


Java RegionAlreadyInTransitionException类代码示例

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


RegionAlreadyInTransitionException类属于org.apache.hadoop.hbase.regionserver包,在下文中一共展示了RegionAlreadyInTransitionException类的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: retrySendRegionClose

import org.apache.hadoop.hbase.regionserver.RegionAlreadyInTransitionException; //导入依赖的package包/类
/**
 * At master failover, for pending_close region, make sure
 * sendRegionClose RPC call is sent to the target regionserver
 */
private void retrySendRegionClose(final RegionState regionState) {
  this.executorService.submit(
    new EventHandler(server, EventType.M_MASTER_RECOVERY) {
      @Override
      public void process() throws IOException {
        HRegionInfo hri = regionState.getRegion();
        ServerName serverName = regionState.getServerName();
        ReentrantLock lock = locker.acquireLock(hri.getEncodedName());
        try {
          for (int i = 1; i <= maximumAttempts; i++) {
            if (!serverManager.isServerOnline(serverName)
                || server.isStopped() || server.isAborted()) {
              return; // No need any more
            }
            try {
              if (!regionState.equals(regionStates.getRegionState(hri))) {
                return; // Region is not in the expected state any more
              }
              if (!serverManager.sendRegionClose(serverName, hri, -1, null, false)) {
                // This means the region is still on the target server
                LOG.debug("Got false in retry sendRegionClose for "
                  + regionState + ", re-close it");
                invokeUnAssign(hri);
              }
              return; // Done.
            } catch (Throwable t) {
              if (t instanceof RemoteException) {
                t = ((RemoteException) t).unwrapRemoteException();
              }
              // In case SocketTimeoutException/FailedServerException, retry
              if (t instanceof java.net.SocketTimeoutException
                  || t instanceof FailedServerException) {
                Threads.sleep(100);
                continue;
              }
              if (!(t instanceof NotServingRegionException
                  || t instanceof RegionAlreadyInTransitionException)) {
                // NotServingRegionException/RegionAlreadyInTransitionException
                // means the target server got the original region close request.
                // For other exceptions, re-close it
                LOG.debug("Got exception in retry sendRegionClose for "
                  + regionState + ", re-close it", t);
                invokeUnAssign(hri);
              }
              return; // Done.
            }
          }
        } finally {
          lock.unlock();
        }
      }
    });
}
 
开发者ID:fengchen8086,项目名称:ditb,代码行数:58,代码来源:AssignmentManager.java

示例2: addRegionsInTransition

import org.apache.hadoop.hbase.regionserver.RegionAlreadyInTransitionException; //导入依赖的package包/类
@Override
public boolean addRegionsInTransition(HRegionInfo region,
    String currentAction) throws RegionAlreadyInTransitionException {
  return super.addRegionsInTransition(region, currentAction);
}
 
开发者ID:fengchen8086,项目名称:LCIndex-HBase-0.94.16,代码行数:6,代码来源:TestZKBasedOpenCloseRegion.java

示例3: unassign

import org.apache.hadoop.hbase.regionserver.RegionAlreadyInTransitionException; //导入依赖的package包/类
/**
 * Send CLOSE RPC if the server is online, otherwise, offline the region
 */
private void unassign(final HRegionInfo region,
    final RegionState state, final int versionOfClosingNode,
    final ServerName dest, final boolean transitionInZK) {
  // Send CLOSE RPC
  ServerName server = state.getServerName();
  // ClosedRegionhandler can remove the server from this.regions
  if (!serverManager.isServerOnline(server)) {
    if (transitionInZK) {
      // delete the node. if no node exists need not bother.
      deleteClosingOrClosedNode(region);
    }
    regionOffline(region);
    return;
  }

  for (int i = 1; i <= this.maximumAttempts; i++) {
    try {
      if (serverManager.sendRegionClose(server, region,
        versionOfClosingNode, dest, transitionInZK)) {
        LOG.debug("Sent CLOSE to " + server + " for region " +
          region.getRegionNameAsString());
        return;
      }
      // This never happens. Currently regionserver close always return true.
      // Todo; this can now happen (0.96) if there is an exception in a coprocessor
      LOG.warn("Server " + server + " region CLOSE RPC returned false for " +
        region.getRegionNameAsString());
    } catch (Throwable t) {
      if (t instanceof RemoteException) {
        t = ((RemoteException)t).unwrapRemoteException();
      }
      if (t instanceof NotServingRegionException) {
        if (transitionInZK) {
          deleteClosingOrClosedNode(region);
        }
        regionOffline(region);
        return;
      } else if (t instanceof RegionAlreadyInTransitionException) {
        // RS is already processing this region, only need to update the timestamp
        LOG.debug("update " + state + " the timestamp.");
        state.updateTimestampToNow();
      }
      LOG.info("Server " + server + " returned " + t + " for "
        + region.getRegionNameAsString() + ", try=" + i
        + " of " + this.maximumAttempts, t);
      // Presume retry or server will expire.
    }
  }
}
 
开发者ID:daidong,项目名称:DominoHBase,代码行数:53,代码来源:AssignmentManager.java


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