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


Java FSImage类代码示例

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


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

示例1: testCheckpointWhenNoNewTransactionsHappened

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
/**
 * Test for the case when the SBN is configured to checkpoint based
 * on a time period, but no transactions are happening on the
 * active. Thus, it would want to save a second checkpoint at the
 * same txid, which is a no-op. This test makes sure this doesn't
 * cause any problem.
 */
@Test
public void testCheckpointWhenNoNewTransactionsHappened()
    throws Exception {
  // Checkpoint as fast as we can, in a tight loop.
  cluster.getConfiguration(1).setInt(
      DFSConfigKeys.DFS_NAMENODE_CHECKPOINT_PERIOD_KEY, 0);
  cluster.restartNameNode(1);
  nn1 = cluster.getNameNode(1);
 
  FSImage spyImage1 = NameNodeAdapter.spyOnFsImage(nn1);
  
  // We shouldn't save any checkpoints at txid=0
  Thread.sleep(1000);
  Mockito.verify(spyImage1, Mockito.never())
    .saveNamespace((FSNamesystem) Mockito.anyObject());
 
  // Roll the primary and wait for the standby to catch up
  HATestUtil.waitForStandbyToCatchUp(nn0, nn1);
  Thread.sleep(2000);
  
  // We should make exactly one checkpoint at this new txid. 
  Mockito.verify(spyImage1, Mockito.times(1))
    .saveNamespace((FSNamesystem) Mockito.anyObject(),
        (Canceler)Mockito.anyObject());       
}
 
开发者ID:ict-carch,项目名称:hadoop-plus,代码行数:33,代码来源:TestStandbyCheckpoints.java

示例2: testCheckpointWhenNoNewTransactionsHappened

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
/**
 * Test for the case when the SBN is configured to checkpoint based
 * on a time period, but no transactions are happening on the
 * active. Thus, it would want to save a second checkpoint at the
 * same txid, which is a no-op. This test makes sure this doesn't
 * cause any problem.
 */
@Test
public void testCheckpointWhenNoNewTransactionsHappened()
    throws Exception {
  // Checkpoint as fast as we can, in a tight loop.
  cluster.getConfiguration(1).setInt(
      DFSConfigKeys.DFS_NAMENODE_CHECKPOINT_PERIOD_KEY, 0);
  cluster.restartNameNode(1);
  nn1 = cluster.getNameNode(1);
 
  FSImage spyImage1 = NameNodeAdapter.spyOnFsImage(nn1);
  
  // We shouldn't save any checkpoints at txid=0
  Thread.sleep(1000);
  Mockito.verify(spyImage1, Mockito.never())
    .saveNamespace((FSNamesystem) Mockito.anyObject());
 
  // Roll the primary and wait for the standby to catch up
  HATestUtil.waitForStandbyToCatchUp(nn0, nn1);
  Thread.sleep(2000);
  
  // We should make exactly one checkpoint at this new txid. 
  Mockito.verify(spyImage1, Mockito.times(1)).saveNamespace(
      (FSNamesystem) Mockito.anyObject(), Mockito.eq(NameNodeFile.IMAGE),
      (Canceler) Mockito.anyObject());
}
 
开发者ID:Seagate,项目名称:hadoop-on-lustre2,代码行数:33,代码来源:TestStandbyCheckpoints.java

示例3: checkImages

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
private void checkImages(FSNamesystem fsn) throws Exception {
  Iterator<StorageDirectory> iter = fsn.
          getFSImage().dirIterator(FSImage.NameNodeDirType.IMAGE);
  List<Long> checksums = new ArrayList<Long>();
  while (iter.hasNext()) {
    StorageDirectory sd = iter.next();
    File fsImage = FSImage.getImageFile(sd, FSImage.NameNodeFile.IMAGE);
    PureJavaCrc32 crc = new PureJavaCrc32();
    FileInputStream in = new FileInputStream(fsImage);
    byte[] buff = new byte[4096];
    int read = 0;
    while ((read = in.read(buff)) != -1) {
     crc.update(buff, 0, read);
    }
    long val = crc.getValue();
    checksums.add(val);
  }
  assertTrue("Not enough fsimage copies in MiniDFSCluster " + 
             "to test parallel write", checksums.size() > 1);
  for (int i = 1; i < checksums.size(); i++) {
    assertEquals(checksums.get(i - 1), checksums.get(i));
  }
}
 
开发者ID:cumulusyebl,项目名称:cumulus,代码行数:24,代码来源:TestParallelImageWrite.java

示例4: checkLogsAvailableForRead

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
private boolean checkLogsAvailableForRead(FSImage image, long imageTxId,
    long curTxIdOnOtherNode) {

  if (imageTxId == curTxIdOnOtherNode) {
    // The other node hasn't written any logs since the last checkpoint.
    // This can be the case if the NN was freshly formatted as HA, and
    // then started in standby mode, so it has no edit logs at all.
    return true;
  }
  long firstTxIdInLogs = imageTxId + 1;
  
  assert curTxIdOnOtherNode >= firstTxIdInLogs :
    "first=" + firstTxIdInLogs + " onOtherNode=" + curTxIdOnOtherNode;
  
  try {
    Collection<EditLogInputStream> streams =
      image.getEditLog().selectInputStreams(
        firstTxIdInLogs, curTxIdOnOtherNode, null, true);
    for (EditLogInputStream stream : streams) {
      IOUtils.closeStream(stream);
    }
    return true;
  } catch (IOException e) {
    String msg = "Unable to read transaction ids " +
        firstTxIdInLogs + "-" + curTxIdOnOtherNode +
        " from the configured shared edits storage " +
        Joiner.on(",").join(sharedEditsUris) + ". " +
        "Please copy these logs into the shared edits storage " + 
        "or call saveNamespace on the active node.\n" +
        "Error: " + e.getLocalizedMessage();
    if (LOG.isDebugEnabled()) {
      LOG.fatal(msg, e);
    } else {
      LOG.fatal(msg);
    }
    return false;
  }
}
 
开发者ID:naver,项目名称:hadoop,代码行数:39,代码来源:BootstrapStandby.java

示例5: checkLogsAvailableForRead

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
private boolean checkLogsAvailableForRead(FSImage image, long imageTxId,
    long curTxIdOnOtherNode) {

  if (imageTxId == curTxIdOnOtherNode) {
    // The other node hasn't written any logs since the last checkpoint.
    // This can be the case if the NN was freshly formatted as HA, and
    // then started in standby mode, so it has no edit logs at all.
    return true;
  }
  long firstTxIdInLogs = imageTxId + 1;
  
  assert curTxIdOnOtherNode >= firstTxIdInLogs :
    "first=" + firstTxIdInLogs + " onOtherNode=" + curTxIdOnOtherNode;
  
  try {
    Collection<EditLogInputStream> streams =
      image.getEditLog().selectInputStreams(
        firstTxIdInLogs, curTxIdOnOtherNode, null, true);
    for (EditLogInputStream stream : streams) {
      IOUtils.closeStream(stream);
    }
    return true;
  } catch (IOException e) {
    String msg = "Unable to read transaction ids " +
        firstTxIdInLogs + "-" + curTxIdOnOtherNode +
        " from the configured shared edits storage " +
        Joiner.on(",").join(sharedEditsUris) + ". " +
        "Please copy these logs into the shared edits storage " + 
        "or call saveNamespace on the active node.\n" +
        "Error: " + e.getLocalizedMessage();
    if (LOG.isDebugEnabled()) {
      LOG.debug(msg, e);
    } else {
      LOG.fatal(msg);
    }
    return false;
  }
}
 
开发者ID:aliyun-beta,项目名称:aliyun-oss-hadoop-fs,代码行数:39,代码来源:BootstrapStandby.java

示例6: CheckpointSignature

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
CheckpointSignature(FSImage fsImage) {
  super(fsImage.getStorage());
  blockpoolID = fsImage.getBlockPoolID();
  
  mostRecentCheckpointTxId = fsImage.getStorage().getMostRecentCheckpointTxId();
  curSegmentTxId = fsImage.getEditLog().getCurSegmentTxId();
}
 
开发者ID:ict-carch,项目名称:hadoop-plus,代码行数:8,代码来源:CheckpointSignature.java

示例7: validateStorageInfo

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
void validateStorageInfo(FSImage si) throws IOException {
  if (!isSameCluster(si)
      || !storageVersionMatches(si.getStorage())) {
    throw new IOException("Inconsistent checkpoint fields.\n"
        + "LV = " + layoutVersion + " namespaceID = " + namespaceID
        + " cTime = " + cTime
        + " ; clusterId = " + clusterID
        + " ; blockpoolId = " + blockpoolID
        + ".\nExpecting respectively: "
        + si.getStorage().layoutVersion + "; " 
        + si.getStorage().namespaceID + "; " + si.getStorage().cTime
        + "; " + si.getClusterID() + "; " 
        + si.getBlockPoolID() + ".");
  }
}
 
开发者ID:ict-carch,项目名称:hadoop-plus,代码行数:16,代码来源:CheckpointSignature.java

示例8: testStandbyExceptionThrownDuringCheckpoint

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
/**
 * Make sure that clients will receive StandbyExceptions even when a
 * checkpoint is in progress on the SBN, and therefore the StandbyCheckpointer
 * thread will have FSNS lock. Regression test for HDFS-4591.
 */
@Test(timeout=300000)
public void testStandbyExceptionThrownDuringCheckpoint() throws Exception {
  
  // Set it up so that we know when the SBN checkpoint starts and ends.
  FSImage spyImage1 = NameNodeAdapter.spyOnFsImage(nn1);
  DelayAnswer answerer = new DelayAnswer(LOG);
  Mockito.doAnswer(answerer).when(spyImage1)
      .saveNamespace(Mockito.any(FSNamesystem.class),
          Mockito.any(Canceler.class));
  
  // Perform some edits and wait for a checkpoint to start on the SBN.
  doEdits(0, 1000);
  nn0.getRpcServer().rollEditLog();
  answerer.waitForCall();
  answerer.proceed();
  assertTrue("SBN is not performing checkpoint but it should be.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 0);
  
  // Make sure that the lock has actually been taken by the checkpointing
  // thread.
  ThreadUtil.sleepAtLeastIgnoreInterrupts(1000);
  try {
    // Perform an RPC to the SBN and make sure it throws a StandbyException.
    nn1.getRpcServer().getFileInfo("/");
    fail("Should have thrown StandbyException, but instead succeeded.");
  } catch (StandbyException se) {
    GenericTestUtils.assertExceptionContains("is not supported", se);
  }
  
  // Make sure that the checkpoint is still going on, implying that the client
  // RPC to the SBN happened during the checkpoint.
  assertTrue("SBN should have still been checkpointing.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 0);
  answerer.waitForResult();
  assertTrue("SBN should have finished checkpointing.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 1);
}
 
开发者ID:ict-carch,项目名称:hadoop-plus,代码行数:43,代码来源:TestStandbyCheckpoints.java

示例9: checkLogsAvailableForRead

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
private boolean checkLogsAvailableForRead(FSImage image, long imageTxId,
    long curTxIdOnOtherNode) {

  if (imageTxId == curTxIdOnOtherNode) {
    // The other node hasn't written any logs since the last checkpoint.
    // This can be the case if the NN was freshly formatted as HA, and
    // then started in standby mode, so it has no edit logs at all.
    return true;
  }
  long firstTxIdInLogs = imageTxId + 1;
  
  assert curTxIdOnOtherNode >= firstTxIdInLogs :
    "first=" + firstTxIdInLogs + " onOtherNode=" + curTxIdOnOtherNode;
  
  try {
    Collection<EditLogInputStream> streams =
      image.getEditLog().selectInputStreams(
        firstTxIdInLogs, curTxIdOnOtherNode, null, true, false);
    for (EditLogInputStream stream : streams) {
      IOUtils.closeStream(stream);
    }
    return true;
  } catch (IOException e) {
    String msg = "Unable to read transaction ids " +
        firstTxIdInLogs + "-" + curTxIdOnOtherNode +
        " from the configured shared edits storage " +
        Joiner.on(",").join(sharedEditsUris) + ". " +
        "Please copy these logs into the shared edits storage " + 
        "or call saveNamespace on the active node.\n" +
        "Error: " + e.getLocalizedMessage();
    if (LOG.isDebugEnabled()) {
      LOG.fatal(msg, e);
    } else {
      LOG.fatal(msg);
    }
    return false;
  }
}
 
开发者ID:chendave,项目名称:hadoop-TCP,代码行数:39,代码来源:BootstrapStandby.java

示例10: testStandbyExceptionThrownDuringCheckpoint

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
/**
 * Make sure that clients will receive StandbyExceptions even when a
 * checkpoint is in progress on the SBN, and therefore the StandbyCheckpointer
 * thread will have FSNS lock. Regression test for HDFS-4591.
 */
@Test(timeout=300000)
public void testStandbyExceptionThrownDuringCheckpoint() throws Exception {
  
  // Set it up so that we know when the SBN checkpoint starts and ends.
  FSImage spyImage1 = NameNodeAdapter.spyOnFsImage(nn1);
  DelayAnswer answerer = new DelayAnswer(LOG);
  Mockito.doAnswer(answerer).when(spyImage1)
      .saveNamespace(Mockito.any(FSNamesystem.class),
          Mockito.eq(NameNodeFile.IMAGE), Mockito.any(Canceler.class));

  // Perform some edits and wait for a checkpoint to start on the SBN.
  doEdits(0, 1000);
  nn0.getRpcServer().rollEditLog();
  answerer.waitForCall();
  assertTrue("SBN is not performing checkpoint but it should be.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 0);
  
  // Make sure that the lock has actually been taken by the checkpointing
  // thread.
  ThreadUtil.sleepAtLeastIgnoreInterrupts(1000);
  try {
    // Perform an RPC to the SBN and make sure it throws a StandbyException.
    nn1.getRpcServer().getFileInfo("/");
    fail("Should have thrown StandbyException, but instead succeeded.");
  } catch (StandbyException se) {
    GenericTestUtils.assertExceptionContains("is not supported", se);
  }
  
  // Make sure that the checkpoint is still going on, implying that the client
  // RPC to the SBN happened during the checkpoint.
  assertTrue("SBN should have still been checkpointing.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 0);
  answerer.proceed();
  answerer.waitForResult();
  assertTrue("SBN should have finished checkpointing.",
      answerer.getFireCount() == 1 && answerer.getResultCount() == 1);
}
 
开发者ID:Seagate,项目名称:hadoop-on-lustre2,代码行数:43,代码来源:TestStandbyCheckpoints.java

示例11: validateStorageInfo

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
void validateStorageInfo(FSImage si) throws IOException {
  if(layoutVersion != si.layoutVersion
      || namespaceID != si.namespaceID || cTime != si.cTime
      || checkpointTime != si.checkpointTime ||
      !imageDigest.equals(si.imageDigest)) {
    // checkpointTime can change when the image is saved - do not compare
    throw new IOException("Inconsistent checkpoint fields.\n"
        + "LV = " + layoutVersion + " namespaceID = " + namespaceID
        + " cTime = " + cTime + "; checkpointTime = " + checkpointTime
        + " ; imageDigest = " + imageDigest
        + ".\nExpecting respectively: "
        + si.layoutVersion + "; " + si.namespaceID + "; " + si.cTime
        + "; " + si.checkpointTime + "; " + si.imageDigest);
  }
}
 
开发者ID:cumulusyebl,项目名称:cumulus,代码行数:16,代码来源:CheckpointSignature.java

示例12: loadCheckpoint

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
/**
 * Load checkpoint from local files only if the memory state is empty.<br>
 * Set new checkpoint time received from the name-node.<br>
 * Move <code>lastcheckpoint.tmp</code> to <code>previous.checkpoint</code>.
 * @throws IOException
 */
void loadCheckpoint(CheckpointSignature sig) throws IOException {
  // load current image and journal if it is not in memory already
  if(!editLog.isOpen())
    editLog.open();

  FSDirectory fsDir = getFSNamesystem().dir;
  if(fsDir.isEmpty()) {
    Iterator<StorageDirectory> itImage = dirIterator(NameNodeDirType.IMAGE);
    Iterator<StorageDirectory> itEdits = dirIterator(NameNodeDirType.EDITS);
    if(!itImage.hasNext() || ! itEdits.hasNext())
      throw new IOException("Could not locate checkpoint directories");
    StorageDirectory sdName = itImage.next();
    StorageDirectory sdEdits = itEdits.next();
    fsDir.writeLock();
    try { // load image under rootDir lock
      // make sure image checksum is verified against the expected value
      imageDigest = sig.imageDigest; 
      loadFSImage(FSImage.getImageFile(sdName, NameNodeFile.IMAGE));
    } finally {
      fsDir.writeUnlock();
    }
    loadFSEdits(sdEdits);
  }

  // set storage fields
  setStorageInfo(sig);
  imageDigest = sig.imageDigest;
  checkpointTime = sig.checkpointTime;
  fsDir.setReady();
  getFSNamesystem().setBlockTotal();
}
 
开发者ID:cumulusyebl,项目名称:cumulus,代码行数:38,代码来源:BackupStorage.java

示例13: doTailEdits

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
@VisibleForTesting
void doTailEdits() throws IOException, InterruptedException {
  // Write lock needs to be interruptible here because the 
  // transitionToActive RPC takes the write lock before calling
  // tailer.stop() -- so if we're not interruptible, it will
  // deadlock.
  namesystem.writeLockInterruptibly();
  try {
    FSImage image = namesystem.getFSImage();

    long lastTxnId = image.getLastAppliedTxId();
    
    if (LOG.isDebugEnabled()) {
      LOG.debug("lastTxnId: " + lastTxnId);
    }
    Collection<EditLogInputStream> streams;
    try {
      streams = editLog.selectInputStreams(lastTxnId + 1, 0, null, false);
    } catch (IOException ioe) {
      // This is acceptable. If we try to tail edits in the middle of an edits
      // log roll, i.e. the last one has been finalized but the new inprogress
      // edits file hasn't been started yet.
      LOG.warn("Edits tailer failed to find any streams. Will try again " +
          "later.", ioe);
      return;
    }
    if (LOG.isDebugEnabled()) {
      LOG.debug("edit streams to load from: " + streams.size());
    }
    
    // Once we have streams to load, errors encountered are legitimate cause
    // for concern, so we don't catch them here. Simple errors reading from
    // disk are ignored.
    long editsLoaded = 0;
    try {
      editsLoaded = image.loadEdits(streams, namesystem);
    } catch (EditLogInputException elie) {
      editsLoaded = elie.getNumEditsLoaded();
      throw elie;
    } finally {
      if (editsLoaded > 0 || LOG.isDebugEnabled()) {
        LOG.info(String.format("Loaded %d edits starting from txid %d ",
            editsLoaded, lastTxnId));
      }
    }

    if (editsLoaded > 0) {
      lastLoadTimeMs = monotonicNow();
    }
    lastLoadedTxnId = image.getLastAppliedTxId();
  } finally {
    namesystem.writeUnlock();
  }
}
 
开发者ID:naver,项目名称:hadoop,代码行数:55,代码来源:EditLogTailer.java

示例14: countUncheckpointedTxns

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
private long countUncheckpointedTxns() {
  FSImage img = namesystem.getFSImage();
  return img.getLastAppliedOrWrittenTxId() -
    img.getStorage().getMostRecentCheckpointTxId();
}
 
开发者ID:naver,项目名称:hadoop,代码行数:6,代码来源:StandbyCheckpointer.java

示例15: testFinalize

import org.apache.hadoop.hdfs.server.namenode.FSImage; //导入依赖的package包/类
@Test (timeout = 300000)
public void testFinalize() throws Exception {
  final Configuration conf = new HdfsConfiguration();
  MiniQJMHACluster cluster = null;
  final Path foo = new Path("/foo");
  final Path bar = new Path("/bar");

  try {
    cluster = new MiniQJMHACluster.Builder(conf).build();
    MiniDFSCluster dfsCluster = cluster.getDfsCluster();
    dfsCluster.waitActive();

    // let NN1 tail editlog every 1s
    dfsCluster.getConfiguration(1).setInt(
        DFSConfigKeys.DFS_HA_TAILEDITS_PERIOD_KEY, 1);
    dfsCluster.restartNameNode(1);

    dfsCluster.transitionToActive(0);
    DistributedFileSystem dfs = dfsCluster.getFileSystem(0);
    dfs.mkdirs(foo);

    FSImage fsimage = dfsCluster.getNamesystem(0).getFSImage();

    // start rolling upgrade
    RollingUpgradeInfo info = dfs
        .rollingUpgrade(RollingUpgradeAction.PREPARE);
    Assert.assertTrue(info.isStarted());
    dfs.mkdirs(bar);

    queryForPreparation(dfs);

    // The NN should have a copy of the fsimage in case of rollbacks.
    Assert.assertTrue(fsimage.hasRollbackFSImage());

    info = dfs.rollingUpgrade(RollingUpgradeAction.FINALIZE);
    Assert.assertTrue(info.isFinalized());
    Assert.assertTrue(dfs.exists(foo));

    // Once finalized, there should be no more fsimage for rollbacks.
    Assert.assertFalse(fsimage.hasRollbackFSImage());

    // Should have no problem in restart and replaying edits that include
    // the FINALIZE op.
    dfsCluster.restartNameNode(0);
  } finally {
    if (cluster != null) {
      cluster.shutdown();
    }
  }
}
 
开发者ID:naver,项目名称:hadoop,代码行数:51,代码来源:TestRollingUpgrade.java


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