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


Java FSInputStream类代码示例

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


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

示例1: testCopyStreamTargetExists

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
@Test
public void testCopyStreamTargetExists() throws Exception {
  FSDataOutputStream out = mock(FSDataOutputStream.class);
  whenFsCreate().thenReturn(out);
  when(mockFs.getFileStatus(eq(path))).thenReturn(fileStat);
  target.refreshStatus(); // so it's updated as existing
  cmd.setOverwrite(true);
  when(mockFs.getFileStatus(eq(tmpPath))).thenReturn(fileStat);
  when(mockFs.delete(eq(path), eq(false))).thenReturn(true);
  when(mockFs.rename(eq(tmpPath), eq(path))).thenReturn(true);
  FSInputStream in = mock(FSInputStream.class);
  when(in.read(any(byte[].class), anyInt(), anyInt())).thenReturn(-1);
  
  tryCopyStream(in, true);
  verify(mockFs).delete(eq(path), anyBoolean());
  verify(mockFs).rename(eq(tmpPath), eq(path));
  verify(mockFs, never()).delete(eq(tmpPath), anyBoolean());
  verify(mockFs, never()).close();
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:20,代码来源:TestCopy.java

示例2: testInterruptedCopyBytes

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
@Test
public void testInterruptedCopyBytes() throws Exception {
  FSDataOutputStream out = mock(FSDataOutputStream.class);
  whenFsCreate().thenReturn(out);
  when(mockFs.getFileStatus(eq(tmpPath))).thenReturn(fileStat);
  FSInputStream in = mock(FSInputStream.class);
  // make IOUtils.copyBytes fail
  when(in.read(any(byte[].class), anyInt(), anyInt())).thenThrow(
      new InterruptedIOException());
  
  tryCopyStream(in, false);
  verify(mockFs).delete(eq(tmpPath), anyBoolean());
  verify(mockFs, never()).rename(any(Path.class), any(Path.class));
  verify(mockFs, never()).delete(eq(path), anyBoolean());
  verify(mockFs, never()).close();
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:17,代码来源:TestCopy.java

示例3: testInterruptedRename

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
@Test
public void testInterruptedRename() throws Exception {
  FSDataOutputStream out = mock(FSDataOutputStream.class);
  whenFsCreate().thenReturn(out);
  when(mockFs.getFileStatus(eq(tmpPath))).thenReturn(fileStat);
  when(mockFs.rename(eq(tmpPath), eq(path))).thenThrow(
      new InterruptedIOException());
  FSInputStream in = mock(FSInputStream.class);
  when(in.read(any(byte[].class), anyInt(), anyInt())).thenReturn(-1);
  
  tryCopyStream(in, false);
  verify(mockFs).delete(eq(tmpPath), anyBoolean());
  verify(mockFs).rename(eq(tmpPath), eq(path));
  verify(mockFs, never()).delete(eq(path), anyBoolean());
  verify(mockFs, never()).close();
}
 
开发者ID:nucypher,项目名称:hadoop-oss,代码行数:17,代码来源:TestCopy.java

示例4: dfsOpenFileWithRetries

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
/**
 * Try to open a file for reading several times.
 * 
 * If we fail because lease recovery hasn't completed, retry the open.
 */
private static FSInputStream dfsOpenFileWithRetries(DistributedFileSystem dfs,
    String pathName) throws IOException {
  IOException exc = null;
  for (int tries = 0; tries < 10; tries++) {
    try {
      return dfs.dfs.open(pathName);
    } catch (IOException e) {
      exc = e;
    }
    if (!exc.getMessage().contains("Cannot obtain " +
        "block length for LocatedBlock")) {
      throw exc;
    }
    try {
      Thread.sleep(1000);
    } catch (InterruptedException ignored) {}
  }
  throw exc;
}
 
开发者ID:naver,项目名称:hadoop,代码行数:25,代码来源:TestDFSUpgradeFromImage.java

示例5: open

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
@Override
public FSDataInputStream open(final Path path, final int bufferSize) throws IOException {
    LOG.debug("Opening '{}' for reading.", path);

    final FileStatus fileStatus = getFileStatus(path);

    if (fileStatus.isDirectory()) {
        final String msg = String.format("Can't open %s because it is a directory", path);
        throw new FileNotFoundException(msg);
    }

    String mantaPath = mantaPath(path);

    MantaSeekableByteChannel channel = client.getSeekableByteChannel(mantaPath);
    FSInputStream fsInput = new MantaSeekableInputStream(channel);

    return new FSDataInputStream(fsInput);
}
 
开发者ID:joyent,项目名称:hadoop-manta,代码行数:19,代码来源:MantaFileSystem.java

示例6: sendPartialData

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
/**
 * Send a partial content response with the given range. If there are
 * no satisfiable ranges, or if multiple ranges are requested, which
 * is unsupported, respond with range not satisfiable.
 *
 * @param in stream to read from
 * @param out stream to write to
 * @param response http response to use
 * @param contentLength for the response header
 * @param ranges to write to respond with
 * @throws IOException on error sending the response
 */
static void sendPartialData(FSInputStream in,
                            OutputStream out,
                            HttpServletResponse response,
                            long contentLength,
                            List<InclusiveByteRange> ranges)
    throws IOException {
  if (ranges == null || ranges.size() != 1) {
    response.setContentLength(0);
    response.setStatus(HttpServletResponse.SC_REQUESTED_RANGE_NOT_SATISFIABLE);
    response.setHeader("Content-Range",
              InclusiveByteRange.to416HeaderRangeString(contentLength));
  } else {
    InclusiveByteRange singleSatisfiableRange = ranges.get(0);
    long singleLength = singleSatisfiableRange.getSize(contentLength);
    response.setStatus(HttpServletResponse.SC_PARTIAL_CONTENT);
    response.setHeader("Content-Range", 
      singleSatisfiableRange.toHeaderRangeString(contentLength));
    copyFromOffset(in, out,
                   singleSatisfiableRange.getFirst(contentLength),
                   singleLength);
  }
}
 
开发者ID:ict-carch,项目名称:hadoop-plus,代码行数:35,代码来源:StreamFile.java

示例7: sendPartialData

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
/**
 * Send a partial content response with the given range. If there are
 * no satisfiable ranges, or if multiple ranges are requested, which
 * is unsupported, respond with range not satisfiable.
 *
 * @param in
 *     stream to read from
 * @param out
 *     stream to write to
 * @param response
 *     http response to use
 * @param contentLength
 *     for the response header
 * @param ranges
 *     to write to respond with
 * @throws IOException
 *     on error sending the response
 */
static void sendPartialData(FSInputStream in, OutputStream out,
    HttpServletResponse response, long contentLength,
    List<InclusiveByteRange> ranges) throws IOException {
  if (ranges == null || ranges.size() != 1) {
    response.setContentLength(0);
    response
        .setStatus(HttpServletResponse.SC_REQUESTED_RANGE_NOT_SATISFIABLE);
    response.setHeader("Content-Range",
        InclusiveByteRange.to416HeaderRangeString(contentLength));
  } else {
    InclusiveByteRange singleSatisfiableRange = ranges.get(0);
    long singleLength = singleSatisfiableRange.getSize(contentLength);
    response.setStatus(HttpServletResponse.SC_PARTIAL_CONTENT);
    response.setHeader("Content-Range",
        singleSatisfiableRange.toHeaderRangeString(contentLength));
    copyFromOffset(in, out, singleSatisfiableRange.getFirst(contentLength),
        singleLength);
  }
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:38,代码来源:StreamFile.java

示例8: testWriteTo

import org.apache.hadoop.fs.FSInputStream; //导入依赖的package包/类
@Test
public void testWriteTo() throws IOException {

  FSInputStream fsin = new MockFSInputStream();
  ByteArrayOutputStream os = new ByteArrayOutputStream();

  // new int[]{s_1, c_1, s_2, c_2, ..., s_n, c_n} means to test
  // reading c_i bytes starting at s_i
  int[] pairs =
      new int[]{0, 10000, 50, 100, 50, 6000, 1000, 2000, 0, 1, 0, 0, 5000,
          0,};

  assertTrue("Pairs array must be even", pairs.length % 2 == 0);
  
  for (int i = 0; i < pairs.length; i += 2) {
    StreamFile.copyFromOffset(fsin, os, pairs[i], pairs[i + 1]);
    assertArrayEquals(
        "Reading " + pairs[i + 1] + " bytes from offset " + pairs[i],
        getOutputArray(pairs[i], pairs[i + 1]), os.toByteArray());
    os.reset();
  }
  
}
 
开发者ID:hopshadoop,项目名称:hops,代码行数:24,代码来源:TestStreamFile.java


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