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


Java MasterProcedureEnv類代碼示例

本文整理匯總了Java中org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv的典型用法代碼示例。如果您正苦於以下問題:Java MasterProcedureEnv類的具體用法?Java MasterProcedureEnv怎麽用?Java MasterProcedureEnv使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MasterProcedureEnv類屬於org.apache.hadoop.hbase.master.procedure包,在下文中一共展示了MasterProcedureEnv類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: startProcedureExecutor

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
private void startProcedureExecutor() throws IOException {
  final MasterProcedureEnv procEnv = new MasterProcedureEnv(this);
  final Path logDir = new Path(fileSystemManager.getRootDir(),
      MasterProcedureConstants.MASTER_PROCEDURE_LOGDIR);

  procedureStore = new WALProcedureStore(conf, fileSystemManager.getFileSystem(), logDir,
      new MasterProcedureEnv.WALStoreLeaseRecovery(this));
  procedureStore.registerListener(new MasterProcedureEnv.MasterProcedureStoreListener(this));
  procedureExecutor = new ProcedureExecutor(conf, procEnv, procedureStore,
      procEnv.getProcedureQueue());

  final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS,
      Math.max(Runtime.getRuntime().availableProcessors(),
        MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));
  final boolean abortOnCorruption = conf.getBoolean(
      MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,
      MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);
  procedureStore.start(numThreads);
  procedureExecutor.start(numThreads, abortOnCorruption);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:HMaster.java

示例2: testAbortProcedure

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Test
public void testAbortProcedure() throws Exception {
  final TableName tableName = TableName.valueOf("testAbortProcedure");
  final ProcedureExecutor<MasterProcedureEnv> procExec =
      TEST_UTIL.getHBaseCluster().getMaster().getMasterProcedureExecutor();
  Procedure proc = new TestTableDDLProcedure(procExec.getEnvironment(), tableName);
  proc.setOwner(USER_OWNER.getShortName());
  final long procId = procExec.submitProcedure(proc);

  AccessTestAction abortProcedureAction = new AccessTestAction() {
    @Override
    public Object run() throws Exception {
      ACCESS_CONTROLLER
      .preAbortProcedure(ObserverContext.createAndPrepare(CP_ENV, null), procExec, procId);
     return null;
    }
  };

  verifyAllowed(abortProcedureAction, SUPERUSER, USER_ADMIN, USER_GROUP_ADMIN);
  verifyAllowed(abortProcedureAction, USER_OWNER);
  verifyDenied(
    abortProcedureAction, USER_RW, USER_RO, USER_NONE, USER_GROUP_READ, USER_GROUP_WRITE);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:24,代碼來源:TestAccessController.java

示例3: testGetProcedures

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Test
public void testGetProcedures() throws Exception {
  final TableName tableName = TableName.valueOf(name.getMethodName());
  final ProcedureExecutor<MasterProcedureEnv> procExec =
      TEST_UTIL.getHBaseCluster().getMaster().getMasterProcedureExecutor();
  Procedure proc = new TestTableDDLProcedure(procExec.getEnvironment(), tableName);
  proc.setOwner(USER_OWNER);
  procExec.submitProcedure(proc);
  final List<Procedure<?>> procList = procExec.getProcedures();

  AccessTestAction getProceduresAction = new AccessTestAction() {
    @Override
    public Object run() throws Exception {
      ACCESS_CONTROLLER
      .postGetProcedures(ObserverContextImpl.createAndPrepare(CP_ENV));
     return null;
    }
  };

  verifyAllowed(getProceduresAction, SUPERUSER, USER_ADMIN, USER_GROUP_ADMIN);
  verifyAllowed(getProceduresAction, USER_OWNER);
  verifyIfNull(
    getProceduresAction, USER_RW, USER_RO, USER_NONE, USER_GROUP_READ, USER_GROUP_WRITE);
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:25,代碼來源:TestAccessController.java

示例4: execute

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
protected synchronized Procedure<MasterProcedureEnv>[] execute(MasterProcedureEnv env)
    throws ProcedureYieldException, ProcedureSuspendedException, InterruptedException {
  if (dispatched) {
    if (succ) {
      return null;
    }
    // retry
    dispatched = false;
  }
  if (!env.getRemoteDispatcher().addOperationToNode(targetServer, this)) {
    LOG.info("Can not add remote operation for refreshing peer {} for {} to {}, " +
      "this usually because the server is already dead, " +
      "give up and mark the procedure as complete", peerId, type, targetServer);
    return null;
  }
  dispatched = true;
  event = new ProcedureEvent<>(this);
  event.suspendIfNotReady(this);
  throw new ProcedureSuspendedException();
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:22,代碼來源:RefreshPeerProcedure.java

示例5: executeFromState

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
protected Flow executeFromState(final MasterProcedureEnv env, final MoveRegionState state)
    throws InterruptedException {
  if (LOG.isTraceEnabled()) {
    LOG.trace(this + " execute state=" + state);
  }
  switch (state) {
    case MOVE_REGION_UNASSIGN:
      addChildProcedure(new UnassignProcedure(plan.getRegionInfo(), plan.getSource(),
          plan.getDestination(), true));
      setNextState(MoveRegionState.MOVE_REGION_ASSIGN);
      break;
    case MOVE_REGION_ASSIGN:
      AssignProcedure assignProcedure = plan.getDestination() == null ?
          new AssignProcedure(plan.getRegionInfo()):
          new AssignProcedure(plan.getRegionInfo(), plan.getDestination());
      addChildProcedure(assignProcedure);
      return Flow.NO_MORE_STATE;
    default:
      throw new UnsupportedOperationException("unhandled state=" + state);
  }
  return Flow.HAS_MORE_STATE;
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:24,代碼來源:MoveRegionProcedure.java

示例6: testRollbackAndDoubleExecution

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Test
public void testRollbackAndDoubleExecution() throws Exception {
  final TableName tableName = TableName.valueOf("testRollbackAndDoubleExecution");
  final ProcedureExecutor<MasterProcedureEnv> procExec = getMasterProcedureExecutor();

  List<RegionInfo> tableRegions = createTable(tableName);

  ProcedureTestingUtility.waitNoProcedureRunning(procExec);
  ProcedureTestingUtility.setKillAndToggleBeforeStoreUpdate(procExec, true);

  RegionInfo[] regionsToMerge = new RegionInfo[2];
  regionsToMerge[0] = tableRegions.get(0);
  regionsToMerge[1] = tableRegions.get(1);

  long procId = procExec.submitProcedure(
    new MergeTableRegionsProcedure(procExec.getEnvironment(), regionsToMerge, true));

  // Failing before MERGE_TABLE_REGIONS_CREATE_MERGED_REGION we should trigger the rollback
  // NOTE: the 5 (number before MERGE_TABLE_REGIONS_CREATE_MERGED_REGION step) is
  // hardcoded, so you have to look at this test at least once when you add a new step.
  int numberOfSteps = 5;
  MasterProcedureTestingUtility.testRollbackAndDoubleExecution(procExec, procId, numberOfSteps,
      true);
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:25,代碼來源:TestMergeTableRegionsProcedure.java

示例7: startProcedureExecutor

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
private void startProcedureExecutor() throws IOException {
  final MasterProcedureEnv procEnv = new MasterProcedureEnv(this);

  procedureStore = new WALProcedureStore(conf,
      new MasterProcedureEnv.WALStoreLeaseRecovery(this));
  procedureStore.registerListener(new MasterProcedureEnv.MasterProcedureStoreListener(this));
  MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();
  procedureExecutor = new ProcedureExecutor<>(conf, procEnv, procedureStore, procedureScheduler);
  configurationManager.registerObserver(procEnv);

  int cpus = Runtime.getRuntime().availableProcessors();
  final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS,
      Math.max((cpus > 0? cpus/4: 0),
          MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));
  final boolean abortOnCorruption = conf.getBoolean(
      MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,
      MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);
  procedureStore.start(numThreads);
  procedureExecutor.start(numThreads, abortOnCorruption);
  procEnv.getRemoteDispatcher().start();
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:22,代碼來源:HMaster.java

示例8: remoteCallFailed

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
public void remoteCallFailed(final MasterProcedureEnv env,
    final ServerName serverName, final IOException exception) {
  final RegionStateNode regionNode = getRegionState(env);
  String msg = exception.getMessage() == null? exception.getClass().getSimpleName():
    exception.getMessage();
  LOG.warn("Remote call failed " + this + "; " + regionNode.toShortString() +
    "; exception=" + msg);
  if (remoteCallFailed(env, regionNode, exception)) {
    // NOTE: This call to wakeEvent puts this Procedure back on the scheduler.
    // Thereafter, another Worker can be in here so DO NOT MESS WITH STATE beyond
    // this method. Just get out of this current processing quickly.
    regionNode.getProcedureEvent().wake(env.getProcedureScheduler());
  }
  // else leave the procedure in suspended state; it is waiting on another call to this callback
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:17,代碼來源:RegionTransitionProcedure.java

示例9: addToRemoteDispatcher

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
/**
 * Be careful! At the end of this method, the procedure has either succeeded
 * and this procedure has been set into a suspended state OR, we failed and
 * this procedure has been put back on the scheduler ready for another worker
 * to pick it up. In both cases, we need to exit the current Worker processing
 * immediately!
 * @return True if we successfully dispatched the call and false if we failed;
 * if failed, we need to roll back any setup done for the dispatch.
 */
protected boolean addToRemoteDispatcher(final MasterProcedureEnv env,
    final ServerName targetServer) {
  assert targetServer == null || targetServer.equals(getRegionState(env).getRegionLocation()):
    "targetServer=" + targetServer + " getRegionLocation=" +
      getRegionState(env).getRegionLocation(); // TODO

  LOG.info("Dispatch " + this + "; " + getRegionState(env).toShortString());

  // Put this procedure into suspended mode to wait on report of state change
  // from remote regionserver. Means Procedure associated ProcedureEvent is marked not 'ready'.
  getRegionState(env).getProcedureEvent().suspend();

  // Tricky because the below call to addOperationToNode can fail. If it fails, we need to
  // backtrack on stuff like the 'suspend' done above -- tricky as the 'wake' requests us -- and
  // ditto up in the caller; it needs to undo state changes. Inside in remoteCallFailed, it does
  // wake to undo the above suspend.
  if (!env.getRemoteDispatcher().addOperationToNode(targetServer, this)) {
    remoteCallFailed(env, targetServer,
        new FailedRemoteDispatchException(this + " to " + targetServer));
    return false;
  }
  return true;
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:33,代碼來源:RegionTransitionProcedure.java

示例10: block

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
/**
 * An ugly utility to be removed when refactor TableNamespaceManager.
 * @throws TimeoutIOException
 */
private static void block(final MasterServices services, final long procId)
throws TimeoutIOException {
  int timeoutInMillis = services.getConfiguration().
      getInt(ClusterSchema.HBASE_MASTER_CLUSTER_SCHEMA_OPERATION_TIMEOUT_KEY,
          ClusterSchema.DEFAULT_HBASE_MASTER_CLUSTER_SCHEMA_OPERATION_TIMEOUT);
  long deadlineTs = EnvironmentEdgeManager.currentTime() + timeoutInMillis;
  ProcedureExecutor<MasterProcedureEnv> procedureExecutor =
      services.getMasterProcedureExecutor();
  while(EnvironmentEdgeManager.currentTime() < deadlineTs) {
    if (procedureExecutor.isFinished(procId)) return;
    // Sleep some
    Threads.sleep(10);
  }
  throw new TimeoutIOException("Procedure pid=" + procId + " is still running");
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:20,代碼來源:TableNamespaceManager.java

示例11: acquireLock

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
protected LockState acquireLock(final MasterProcedureEnv env) {
  // Unless we are assigning meta, wait for meta to be available and loaded.
  if (!isMeta() && (env.waitFailoverCleanup(this) ||
      env.getAssignmentManager().waitMetaInitialized(this, getRegionInfo()))) {
    return LockState.LOCK_EVENT_WAIT;
  }

  // TODO: Revisit this and move it to the executor
  if (env.getProcedureScheduler().waitRegion(this, getRegionInfo())) {
    try {
      LOG.debug(LockState.LOCK_EVENT_WAIT + " pid=" + getProcId() + " " +
        env.getProcedureScheduler().dumpLocks());
    } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return LockState.LOCK_EVENT_WAIT;
  }
  this.lock = true;
  return LockState.LOCK_ACQUIRED;
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:23,代碼來源:RegionTransitionProcedure.java

示例12: execute

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
protected Procedure<MasterProcedureEnv>[] execute(final MasterProcedureEnv env)
throws ProcedureSuspendedException {
  // Local master locks don't store any state, so on recovery, simply finish this procedure
  // immediately.
  if (recoveredMasterLock) return null;
  if (lockAcquireLatch != null) {
    lockAcquireLatch.countDown();
  }
  if (unlock.get() || hasHeartbeatExpired()) {
    locked.set(false);
    LOG.debug((unlock.get()? "UNLOCKED " : "TIMED OUT ") + toString());
    return null;
  }
  synchronized (event) {
    event.suspend();
    event.suspendIfNotReady(this);
    setState(ProcedureProtos.ProcedureState.WAITING_TIMEOUT);
  }
  throw new ProcedureSuspendedException();
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:22,代碼來源:LockProcedure.java

示例13: acquireLock

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
protected LockState acquireLock(final MasterProcedureEnv env) {
  if (env.waitInitialized(this)) return LockState.LOCK_EVENT_WAIT;
  if (env.getProcedureScheduler().waitRegions(this, getTableName(),
      mergedRegion, regionsToMerge[0], regionsToMerge[1])) {
    try {
      LOG.debug(LockState.LOCK_EVENT_WAIT + " " + env.getProcedureScheduler().dumpLocks());
    } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return LockState.LOCK_EVENT_WAIT;
  }
  this.lock = true;
  return LockState.LOCK_ACQUIRED;
}
 
開發者ID:apache,項目名稱:hbase,代碼行數:17,代碼來源:MergeTableRegionsProcedure.java

示例14: preAbortProcedure

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
@Override
public void preAbortProcedure(
    ObserverContext<MasterCoprocessorEnvironment> ctx,
    final ProcedureExecutor<MasterProcedureEnv> procEnv,
    final long procId) throws IOException {
  if (!procEnv.isProcedureOwner(procId, getActiveUser())) {
    // If the user is not the procedure owner, then we should further probe whether
    // he can abort the procedure.
    requirePermission("abortProcedure", Action.ADMIN);
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:12,代碼來源:AccessController.java

示例15: preAbortProcedure

import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv; //導入依賴的package包/類
public boolean preAbortProcedure(
    final ProcedureExecutor<MasterProcedureEnv> procEnv,
    final long procId) throws IOException {
  return execOperation(coprocessors.isEmpty() ? null : new CoprocessorOperation() {
    @Override
    public void call(MasterObserver oserver, ObserverContext<MasterCoprocessorEnvironment> ctx)
        throws IOException {
      oserver.preAbortProcedure(ctx, procEnv, procId);
    }
  });
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:12,代碼來源:MasterCoprocessorHost.java


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