• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java FSEditLogLoader类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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



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

示例1: BookKeeperEditLogInputStream

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
/**
 * Construct BookKeeper edit log input stream. 
 * Starts reading from firstBookKeeperEntry. This allows the stream
 * to take a shortcut during recovery, as it doesn't have to read
 * every edit log transaction to find out what the last one is.
 */
BookKeeperEditLogInputStream(LedgerHandle lh, EditLogLedgerMetadata metadata,
                             long firstBookKeeperEntry) 
    throws IOException {
  this.lh = lh;
  this.firstTxId = metadata.getFirstTxId();
  this.lastTxId = metadata.getLastTxId();
  this.logVersion = metadata.getDataLayoutVersion();
  this.inProgress = metadata.isInProgress();

  if (firstBookKeeperEntry < 0
      || firstBookKeeperEntry > lh.getLastAddConfirmed()) {
    throw new IOException("Invalid first bk entry to read: "
        + firstBookKeeperEntry + ", LAC: " + lh.getLastAddConfirmed());
  }
  BufferedInputStream bin = new BufferedInputStream(
      new LedgerInputStream(lh, firstBookKeeperEntry));
  tracker = new FSEditLogLoader.PositionTrackingInputStream(bin);
  DataInputStream in = new DataInputStream(tracker);

  reader = new FSEditLogOp.Reader(in, tracker, logVersion);
}
 
开发者ID:naver,项目名称:hadoop,代码行数:28,代码来源:BookKeeperEditLogInputStream.java


示例2: BookKeeperEditLogInputStream

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
/**
 * Construct BookKeeper edit log input stream. 
 * Starts reading from firstBookKeeperEntry. This allows the stream
 * to take a shortcut during recovery, as it doesn't have to read
 * every edit log transaction to find out what the last one is.
 */
BookKeeperEditLogInputStream(LedgerHandle lh, EditLogLedgerMetadata metadata,
                             long firstBookKeeperEntry) 
    throws IOException {
  this.lh = lh;
  this.firstTxId = metadata.getFirstTxId();
  this.lastTxId = metadata.getLastTxId();
  this.logVersion = metadata.getDataLayoutVersion();
  this.inProgress = metadata.isInProgress();

  if (firstBookKeeperEntry < 0
      || firstBookKeeperEntry > lh.getLastAddConfirmed()) {
    throw new IOException("Invalid first bk entry to read: "
        + firstBookKeeperEntry + ", LAC: " + lh.getLastAddConfirmed());
  }
  BufferedInputStream bin = new BufferedInputStream(
      new LedgerInputStream(lh, firstBookKeeperEntry));
  tracker = new FSEditLogLoader.PositionTrackingInputStream(bin);
  DataInputStream in = new DataInputStream(tracker);

  reader = FSEditLogOp.Reader.create(in, tracker, logVersion);
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:28,代码来源:BookKeeperEditLogInputStream.java


示例3: validateEditLog

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
public static FSEditLogLoader.EditLogValidation validateEditLog(
    LedgerHandleProvider ledgerProvider,
    EditLogLedgerMetadata ledgerMetadata) throws IOException {
  BookKeeperEditLogInputStream in;
  try {
    in = new BookKeeperEditLogInputStream(ledgerProvider,
        ledgerMetadata.getLedgerId(), 0, ledgerMetadata.getFirstTxId(),
        ledgerMetadata.getLastTxId(), ledgerMetadata.getLastTxId() == -1);
  } catch (LedgerHeaderCorruptException e) {
    LOG.warn("Log at ledger id" + ledgerMetadata.getLedgerId() +
        " has no valid header", e);
    return new FSEditLogLoader.EditLogValidation(0,
        HdfsConstants.INVALID_TXID, HdfsConstants.INVALID_TXID, true);
  }

  try {
    return FSEditLogLoader.validateEditLog(in);
  } finally {
    IOUtils.closeStream(in);
  }
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:22,代码来源:BookKeeperEditLogInputStream.java


示例4: validateAndGetEndTxId

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
long validateAndGetEndTxId(EditLogLedgerMetadata ledger, boolean fence)
    throws IOException {
  FSEditLogLoader.EditLogValidation val;
  if (!fence) {
    val = BookKeeperEditLogInputStream.validateEditLog(this, ledger);
  } else {
    val = BookKeeperEditLogInputStream.validateEditLog(
        new FencingLedgerHandleProvider(), ledger);
  }
  InjectionHandler.processEvent(InjectionEvent.BKJM_VALIDATELOGSEGMENT,
      val);
  if (val.getNumTransactions() == 0) {
    return HdfsConstants.INVALID_TXID; // Ledger is corrupt
  }
  return val.getEndTxId();
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:17,代码来源:BookKeeperJournalManager.java


示例5: testFailoverRetryStandbyQuiesce

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
@Test
public void testFailoverRetryStandbyQuiesce() throws Exception {
  setUp("testFailoverRetryBlocksMisMatch", false);
  int totalBlocks = 50;
  DFSTestUtil.createFile(fs, new Path("/testFailoverRetryBlocksMisMatch"),
      (long) totalBlocks * 1024, (short) 3, System.currentTimeMillis());
  // This should shutdown the standby.
  cluster.getStandbyAvatar(0).avatar
      .quiesceStandby(FSEditLogLoader.TXID_IGNORE);
  while (!restartDone) {
    LOG.info("Waiting for restart..");
    Thread.sleep(1000);
  }
  try {
    tryConnect(cluster.getStandbyAvatar(0).avatar);
    fail("Did not throw exception");
  } catch (Exception e) {
    LOG.warn("Expected exception : ", e);
  }
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:21,代码来源:TestStandbyFailoverRetry.java


示例6: URLLogInputStream

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
URLLogInputStream(AsyncLogger logger, long firstTxId, int httpTimeout)
    throws LogHeaderCorruptException, IOException {
  log = new URLLog(logger, firstTxId, httpTimeout);
  fStream = log.getInputStream(0);
  
  lastValidTxId = log.getLastValidTxId();
  super.setIsInProgress(log.getIsInProgress());

  BufferedInputStream bin = new BufferedInputStream(fStream);  
  tracker = new FSEditLogLoader.PositionTrackingInputStream(bin);  
  DataInputStream in = new DataInputStream(tracker);

  try {
    logVersion = readLogVersion(in);
  } catch (EOFException eofe) {
    throw new LogHeaderCorruptException("No header found in log");
  }
  reader = new FSEditLogOp.Reader(in, logVersion);
  this.firstTxId = firstTxId;
  this.disabled = false;
  // set initial position (version is 4 bytes)
  this.currentPosition = tracker.getPos();
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:24,代码来源:URLLogInputStream.java


示例7: _processEvent

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
@Override
protected void _processEvent(InjectionEventI event, Object... args) {
  if (event == InjectionEvent.BKJM_STARTLOGSEGMENT) {
    ledgerForStartedSegment = (EditLogLedgerMetadata) args[0];
  } else if (event == InjectionEvent.BKJM_VALIDATELOGSEGMENT) {
    logValidation = (FSEditLogLoader.EditLogValidation) args[0];
  }
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:9,代码来源:TestBookKeeperJournalManager.java


示例8: testQuiesceInterruption

import org.apache.hadoop.hdfs.server.namenode.FSEditLogLoader; //导入依赖的package包/类
protected static TestAvatarCheckpointingHandler testQuiesceInterruption(
    InjectionEvent stopOnEvent, InjectionEvent waitUntilEvent, boolean scf,
    boolean testCancellation, boolean rollAfterQuiesce,
    boolean enableQJM) throws Exception {
  LOG.info("TEST Quiesce during checkpoint : " + stopOnEvent
      + " waiting on: " + waitUntilEvent);
  TestAvatarCheckpointingHandler h = new TestAvatarCheckpointingHandler(
      stopOnEvent, waitUntilEvent, scf);
  InjectionHandler.set(h);
  setUp(3, "testQuiesceInterruption", false, enableQJM); //simulate interruption, no ckpt failure   
  
  AvatarNode primary = cluster.getPrimaryAvatar(0).avatar;
  AvatarNode standby = cluster.getStandbyAvatar(0).avatar;
  createEdits(40);

  while (!h.receivedEvents.contains(stopOnEvent)) {
    LOG.info("Waiting for event : " + stopOnEvent);
    Thread.sleep(1000);
  }
  
  if (!enableQJM) {
  	standby.quiesceStandby(getCurrentTxId(primary)-1);
  	// only assert this for FileJournalManager.
  	// edits + SLS + ELS + SLS (checkpoint fails, but roll happened)
   assertEquals(43, getCurrentTxId(primary));
   
   // if quiesce happened before roll, the standby will be behind by 1 transaction
   // which will be reclaimed by opening the log after
   long extraTransaction = rollAfterQuiesce ? 1 : 0;
   assertEquals(getCurrentTxId(primary), getCurrentTxId(standby) + extraTransaction);
  } else {
  	standby.quiesceStandby(FSEditLogLoader.TXID_IGNORE);
  }
  
  // make sure the checkpoint indeed failed
  assertTrue(h.receivedEvents
      .contains(InjectionEvent.STANDBY_EXIT_CHECKPOINT_EXCEPTION));
  if (testCancellation) {
    assertTrue(h.receivedEvents
        .contains(InjectionEvent.SAVE_NAMESPACE_CONTEXT_EXCEPTION));
  }
  return h;
}
 
开发者ID:rhli,项目名称:hadoop-EAR,代码行数:44,代码来源:TestAvatarCheckpointing.java



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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java CqlConfigHelper类代码示例发布时间:2022-05-22
下一篇:
Java StoredObject类代码示例发布时间:2022-05-22
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap