我正在编写一些 Java 代码,这些代码最终将在应用服务器中用于访问一些非常大的文件(超过 1GB,低于 20GB),这些文件可能托管在 NFS 共享上。为单个请求提供服务将涉及执行以下操作:
- 找到我需要阅读的大文件
- 导航到该文件中的随机点
- 从该文件中读取字节(通常小于 1MB)
- 返回那些字节
我现在有一些简单的 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 上。也不清楚如何共享大文件。聚苯乙烯。应用服务器可能配置在集群中,因此两个不同的应用服务器可能需要同时读取同一个大型共享文件。