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


Java RecoveringBlock.getBlock方法代码示例

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


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

示例1: logRecoverBlock

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
private static void logRecoverBlock(String who, RecoveringBlock rb) {
  ExtendedBlock block = rb.getBlock();
  DatanodeInfo[] targets = rb.getLocations();
  
  LOG.info(who + " calls recoverBlock(" + block
      + ", targets=[" + Joiner.on(", ").join(targets) + "]"
      + ", newGenerationStamp=" + rb.getNewGenerationStamp() + ")");
}
 
开发者ID:naver,项目名称:hadoop,代码行数:9,代码来源:DataNode.java

示例2: initReplicaRecovery

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
@Override
public ReplicaRecoveryInfo initReplicaRecovery(RecoveringBlock rBlock)
throws IOException {
  ExtendedBlock b = rBlock.getBlock();
  final Map<Block, BInfo> map = getMap(b.getBlockPoolId());
  BInfo binfo = map.get(b.getLocalBlock());
  if (binfo == null) {
    throw new IOException("No such Block " + b );  
  }

  return new ReplicaRecoveryInfo(binfo.getBlockId(), binfo.getBytesOnDisk(), 
      binfo.getGenerationStamp(), 
      binfo.isFinalized()?ReplicaState.FINALIZED : ReplicaState.RBW);
}
 
开发者ID:naver,项目名称:hadoop,代码行数:15,代码来源:SimulatedFSDataset.java

示例3: RecoveryTaskContiguous

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
RecoveryTaskContiguous(RecoveringBlock rBlock) {
  this.rBlock = rBlock;
  block = rBlock.getBlock();
  bpid = block.getBlockPoolId();
  locs = rBlock.getLocations();
  recoveryId = rBlock.getNewGenerationStamp();
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:8,代码来源:BlockRecoveryWorker.java

示例4: logRecoverBlock

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
private static void logRecoverBlock(String who, RecoveringBlock rb) {
  ExtendedBlock block = rb.getBlock();
  DatanodeInfo[] targets = rb.getLocations();

  LOG.info(who + " calls recoverBlock(" + block
      + ", targets=[" + Joiner.on(", ").join(targets) + "]"
      + ", newGenerationStamp=" + rb.getNewGenerationStamp()
      + ", newBlock=" + rb.getNewBlock()
      + ", isStriped=" + rb.isStriped()
      + ")");
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:12,代码来源:BlockRecoveryWorker.java

示例5: logRecoverBlock

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
private static void logRecoverBlock(String who, RecoveringBlock rb) {
  ExtendedBlock block = rb.getBlock();
  DatanodeInfo[] targets = rb.getLocations();
  
  LOG.info(who + " calls recoverBlock(" + block + ", targets=[" +
      Joiner.on(", ").join(targets) + "]" + ", newGenerationStamp=" +
      rb.getNewGenerationStamp() + ")");
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:9,代码来源:DataNode.java

示例6: initReplicaRecovery

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
@Override
public ReplicaRecoveryInfo initReplicaRecovery(RecoveringBlock rBlock)
    throws IOException {
  ExtendedBlock b = rBlock.getBlock();
  final Map<Block, BInfo> map = getMap(b.getBlockPoolId());
  BInfo binfo = map.get(b.getLocalBlock());
  if (binfo == null) {
    throw new IOException("No such Block " + b);
  }

  return new ReplicaRecoveryInfo(binfo.getBlockId(), binfo.getBytesOnDisk(),
      binfo.getGenerationStamp(),
      binfo.isFinalized() ? ReplicaState.FINALIZED : ReplicaState.RBW);
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:15,代码来源:SimulatedFSDataset.java

示例7: recoverBlock

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
/** Recover a block */
private void recoverBlock(RecoveringBlock rBlock) throws IOException {
  ExtendedBlock block = rBlock.getBlock();
  String blookPoolId = block.getBlockPoolId();
  DatanodeID[] datanodeids = rBlock.getLocations();
  List<BlockRecord> syncList = new ArrayList<BlockRecord>(datanodeids.length);
  int errorCount = 0;

  //check generation stamps
  for(DatanodeID id : datanodeids) {
    try {
      BPOfferService bpos = blockPoolManager.get(blookPoolId);
      DatanodeRegistration bpReg = bpos.bpRegistration;
      InterDatanodeProtocol datanode = bpReg.equals(id)?
          this: DataNode.createInterDataNodeProtocolProxy(id, getConf(),
              dnConf.socketTimeout, dnConf.connectToDnViaHostname);
      ReplicaRecoveryInfo info = callInitReplicaRecovery(datanode, rBlock);
      if (info != null &&
          info.getGenerationStamp() >= block.getGenerationStamp() &&
          info.getNumBytes() > 0) {
        syncList.add(new BlockRecord(id, datanode, info));
      }
    } catch (RecoveryInProgressException ripE) {
      InterDatanodeProtocol.LOG.warn(
          "Recovery for replica " + block + " on data-node " + id
          + " is already in progress. Recovery id = "
          + rBlock.getNewGenerationStamp() + " is aborted.", ripE);
      return;
    } catch (IOException e) {
      ++errorCount;
      InterDatanodeProtocol.LOG.warn(
          "Failed to obtain replica info for block (=" + block 
          + ") from datanode (=" + id + ")", e);
    }
  }

  if (errorCount == datanodeids.length) {
    throw new IOException("All datanodes failed: block=" + block
        + ", datanodeids=" + Arrays.asList(datanodeids));
  }

  syncBlock(rBlock, syncList);
}
 
开发者ID:naver,项目名称:hadoop,代码行数:44,代码来源:DataNode.java

示例8: recoverBlock

import org.apache.hadoop.hdfs.server.protocol.BlockRecoveryCommand.RecoveringBlock; //导入方法依赖的package包/类
/**
 * Recover a block
 */
private void recoverBlock(RecoveringBlock rBlock) throws IOException {
  ExtendedBlock block = rBlock.getBlock();
  String blookPoolId = block.getBlockPoolId();
  DatanodeID[] datanodeids = rBlock.getLocations();
  List<BlockRecord> syncList = new ArrayList<>(datanodeids.length);
  int errorCount = 0;

  //check generation stamps
  for (DatanodeID id : datanodeids) {
    try {
      BPOfferService bpos = blockPoolManager.get(blookPoolId);
      DatanodeRegistration bpReg = bpos.bpRegistration;
      InterDatanodeProtocol datanode = bpReg.equals(id) ? this : DataNode
          .createInterDataNodeProtocolProxy(id, getConf(),
              dnConf.socketTimeout, dnConf.connectToDnViaHostname);
      ReplicaRecoveryInfo info = callInitReplicaRecovery(datanode, rBlock);
      if (info != null &&
          info.getGenerationStamp() >= block.getGenerationStamp() &&
          info.getNumBytes() > 0) {
        syncList.add(new BlockRecord(id, datanode, info));
      }
    } catch (RecoveryInProgressException ripE) {
      InterDatanodeProtocol.LOG.warn(
          "Recovery for replica " + block + " on data-node " + id +
              " is already in progress. Recovery id = " +
              rBlock.getNewGenerationStamp() + " is aborted.", ripE);
      return;
    } catch (IOException e) {
      ++errorCount;
      InterDatanodeProtocol.LOG.warn(
          "Failed to obtain replica info for block (=" + block +
              ") from datanode (=" + id + ")", e);
    }
  }

  if (errorCount == datanodeids.length) {
    throw new IOException(
        "All datanodes failed: block=" + block + ", datanodeids=" +
            Arrays.asList(datanodeids));
  }

  syncBlock(rBlock, syncList);
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:47,代码来源:DataNode.java


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