5

我正在编写一些 Java 代码,这些代码最终将在应用服务器中用于访问一些非常大的文件(超过 1GB,低于 20GB),这些文件可能托管在 NFS 共享上。为单个请求提供服务将涉及执行以下操作:

  1. 找到我需要阅读的大文件
  2. 导航到该文件中的随机点
  3. 从该文件中读取字节(通常小于 1MB)
  4. 返回那些字节

我现在有一些简单的 POC 代码,它只是打开一个新的只读文件并关闭它:

RandomAccessFile raf=new RandomAccessFile(myFileName, "r");
try{
   byte[] buffer = new byte[size];
   raf.seek(position);
   raf.reafFully(buffer);
   return buffer;
}
finally{
   raf.close();
}

我想知道这是否是一种优雅简单的方法,应该可以很好地工作,还是一种愚蠢的简单方法,在重负载下会出现很多问题(也许我需要建立一个线程安全的读者池等)。显然测试这个假设是最好的,但我想知道这两种方法是否有任何最佳实践或已知问题。到目前为止,我还无法弄清楚谷歌搜索...

谢谢!

PS。目前尚不清楚最终版本是托管在 Windows 还是 *nix 上。也不清楚如何共享大文件。聚苯乙烯。应用服务器可能配置在集群中,因此两个不同的应用服务器可能需要同时读取同一个大型共享文件。

4

1 回答 1

2

另一种选择是java NIO,即FileChannel。FileChannel 也是可导航的,它可能比 RandomAccessFile 更快,因为它可以使用所谓的直接缓冲区。它有一些更有趣的特性,例如它是可中断的。

于 2012-11-29T15:54:48.910 回答