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


Java INode類代碼示例

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


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

示例1: listStatus

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public FileStatus[] listStatus(Path f) throws IOException {
  Path absolutePath = makeAbsolute(f);
  INode inode = store.retrieveINode(absolutePath);
  if (inode == null) {
    throw new FileNotFoundException("File " + f + " does not exist.");
  }
  if (inode.isFile()) {
    return new FileStatus[] {
        new S3FileStatus(f.makeQualified(this), inode)
    };
  }
  ArrayList<FileStatus> ret = new ArrayList<FileStatus>();
  for (Path p : store.listSubPaths(absolutePath)) {
    ret.add(getFileStatus(p.makeQualified(this)));
  }
  return ret.toArray(new FileStatus[0]);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:19,代碼來源:SmallBlockS3FileSystem.java

示例2: create

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public FSDataOutputStream create(Path file, FsPermission permission,
                                 boolean overwrite, int bufferSize,
                                 short replication, long blockSize, Progressable progress)
    throws IOException {

  INode inode = store.retrieveINode(makeAbsolute(file));
  if (inode != null) {
    if (overwrite) {
      delete(file, true);
    } else {
      throw new IOException("File already exists: " + file);
    }
  } else {
    Path parent = file.getParent();
    if (parent != null) {
      if (!mkdirs(parent)) {
        throw new IOException("Mkdirs failed to create " + parent.toString());
      }
    }
  }
  return new FSDataOutputStream
      (new S3OutputStream(getConf(), store, makeAbsolute(file),
          blockSize, progress, bufferSize),
          statistics);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:27,代碼來源:SmallBlockS3FileSystem.java

示例3: renameRecursive

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private boolean renameRecursive(Path src, Path dst) throws IOException {
  INode srcINode = store.retrieveINode(src);
  store.storeINode(dst, srcINode);
  store.deleteINode(src);
  if (srcINode.isDirectory()) {
    for (Path oldSrc : store.listDeepSubPaths(src)) {
      INode inode = store.retrieveINode(oldSrc);
      if (inode == null) {
        return false;
      }
      String oldSrcPath = oldSrc.toUri().getPath();
      String srcPath = src.toUri().getPath();
      String dstPath = dst.toUri().getPath();
      Path newDst = new Path(oldSrcPath.replaceFirst(srcPath, dstPath));
      store.storeINode(newDst, inode);
      store.deleteINode(oldSrc);
    }
  }
  return true;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:21,代碼來源:SmallBlockS3FileSystem.java

示例4: isFile

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public boolean isFile(Path path) throws IOException {
  INode inode = store.retrieveINode(makeAbsolute(path));
  if (inode == null) {
    return false;
  }
  return inode.isFile();
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:9,代碼來源:SmallBlockS3FileSystem.java

示例5: checkFile

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private INode checkFile(Path path) throws IOException {
  INode inode = store.retrieveINode(makeAbsolute(path));
  if (inode == null) {
    throw new IOException("No such file.");
  }
  if (inode.isDirectory()) {
    throw new IOException("Path " + path + " is a directory.");
  }
  return inode;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:11,代碼來源:SmallBlockS3FileSystem.java

示例6: rename

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public boolean rename(Path src, Path dst) throws IOException {
  Path absoluteSrc = makeAbsolute(src);
  INode srcINode = store.retrieveINode(absoluteSrc);
  if (srcINode == null) {
    // src path doesn't exist
    return false;
  }
  Path absoluteDst = makeAbsolute(dst);
  INode dstINode = store.retrieveINode(absoluteDst);
  if (dstINode != null && dstINode.isDirectory()) {
    absoluteDst = new Path(absoluteDst, absoluteSrc.getName());
    dstINode = store.retrieveINode(absoluteDst);
  }
  if (dstINode != null) {
    // dst path already exists - can't overwrite
    return false;
  }
  Path dstParent = absoluteDst.getParent();
  if (dstParent != null) {
    INode dstParentINode = store.retrieveINode(dstParent);
    if (dstParentINode == null || dstParentINode.isFile()) {
      // dst parent doesn't exist or is a file
      return false;
    }
  }
  return renameRecursive(absoluteSrc, absoluteDst);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:29,代碼來源:SmallBlockS3FileSystem.java

示例7: delete

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public boolean delete(Path path, boolean recursive) throws IOException {
  Path absolutePath = makeAbsolute(path);
  INode inode = store.retrieveINode(absolutePath);
  if (inode == null) {
    return false;
  }
  if (inode.isFile()) {
    store.deleteINode(absolutePath);
    for (Block block: inode.getBlocks()) {
      store.deleteBlock(block);
    }
  } else {
    FileStatus[] contents = null;
    try {
      contents = listStatus(absolutePath);
    } catch(FileNotFoundException fnfe) {
      return false;
    }

    if ((contents.length !=0) && (!recursive)) {
      throw new IOException("Directory " + path.toString()
          + " is not empty.");
    }
    for (FileStatus p:contents) {
      if (!delete(p.getPath(), recursive)) {
        return false;
      }
    }
    store.deleteINode(absolutePath);
  }
  return true;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:34,代碼來源:SmallBlockS3FileSystem.java

示例8: getFileStatus

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
/**
 * FileStatus for S3 file systems.
 */
@Override
public FileStatus getFileStatus(Path f)  throws IOException {
  INode inode = store.retrieveINode(makeAbsolute(f));
  if (inode == null) {
    throw new FileNotFoundException(f + ": No such file or directory.");
  }
  return new S3FileStatus(f.makeQualified(this), inode);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:12,代碼來源:SmallBlockS3FileSystem.java

示例9: mkdir

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private boolean mkdir(Path path) throws IOException {
  Path absolutePath = makeAbsolute(path);
  INode inode = store.retrieveINode(absolutePath);
  if (inode == null) {
    store.storeINode(absolutePath, INode.DIRECTORY_INODE);
  } else if (inode.isFile()) {
    throw new IOException(String.format(
        "Can't make directory for path %s since it is a file.",
        absolutePath));
  }
  return true;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:13,代碼來源:SmallBlockS3FileSystem.java

示例10: findLength

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private static long findLength(INode inode) {
  if (!inode.isDirectory()) {
    long length = 0L;
    for (Block block : inode.getBlocks()) {
      length += block.getLength();
    }
    return length;
  }
  return 0;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:11,代碼來源:SmallBlockS3FileSystem.java

示例11: endBlock

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private synchronized void endBlock() throws IOException {
  //
  // Done with local copy
  //
  backupStream.close();

  //
  // Send it to S3
  //
  // TODO: Use passed in Progressable to report progress.
  nextBlockOutputStream();
  store.storeBlock(nextBlock, backupFile);
  Block[] arr = new Block[blocks.size()];
  arr = blocks.toArray(arr);
  store.storeINode(path, new INode(INode.FILE_TYPES[1], arr));

  //
  // Delete local backup, start new one
  //
  boolean b = backupFile.delete();
  if (!b) {
    LOG.warn("Ignoring failed delete");
  }
  backupFile = newBackupFile();
  backupStream = new FileOutputStream(backupFile);
  bytesWrittenToBlock = 0;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:28,代碼來源:S3OutputStream.java

示例12: S3FileStatus

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
S3FileStatus(Path f, INode inode) throws IOException {
  super(findLength(inode), inode.isDirectory(), 1,
      findBlocksize(inode), 0, f);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:5,代碼來源:SmallBlockS3FileSystem.java

示例13: findBlocksize

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
private static long findBlocksize(INode inode) {
  final Block[] ret = inode.getBlocks();
  return ret == null ? 0L : ret[0].getLength();
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:5,代碼來源:SmallBlockS3FileSystem.java

示例14: retrieveINode

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public INode retrieveINode(Path path) throws IOException {
  return inodes.get(normalize(path));
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:5,代碼來源:InMemoryFileSystemStore.java

示例15: storeINode

import org.apache.hadoop.fs.s3.INode; //導入依賴的package包/類
@Override
public void storeINode(Path path, INode inode) throws IOException {
  inodes.put(normalize(path), inode);
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:5,代碼來源:InMemoryFileSystemStore.java


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