java打开的文件过多_Java IOException“打开的文件太多”

在Linux和其他UNIX /类似UNIX的平台上,操作系统对进程在任何给定时间可能具有的打开文件描述符的数量进行了限制。在过去,此限制曾经是硬接线1,并且相对较小。如今,它要大得多(几百/几千),并且受“软”每进程可配置资源限制。(查找ulimit内置的shell ...)

您的Java应用程序必须超出每个进程的文件描述符限制。

您说打开了19个文件,几百次之后,您得到一个IOException消息,说“打开的文件太多”。现在,仅当请求新的文件描述符时,才可能发生这种特殊的异常。即,当您打开文件(或管道或插座)时。您可以通过打印IOException的堆栈跟踪来验证这一点。

除非您的应用程序以很小的资源限制运行(这似乎不太可能),否则必须重复打开文件/套接字/管道,然后无法关闭它们。找出发生这种情况的原因,您应该能够弄清楚该怎么做。

仅供参考,以下模式是一种写入文件的安全方法,可以保证不会泄漏文件描述符。

Writer w = new FileWriter(...);

try {

// write stuff to the file

} finally {

try {

w.close();

} catch (IOException ex) {

// Log error writing file and bail out.

}

}

1-硬接线,如编译到内核中一样。更改可用fd插槽的数量需要重新编译...并可能导致更少的内存可用于其他用途。在Unix通常在16位计算机上运行的时代,这些事情确实很重要。

更新

Java 7的方式更加简洁:

try (Writer w = new FileWriter(...)) {

// write stuff to the file

} // the `w` resource is automatically closed

更新2

显然,您在尝试运行外部程序时也会遇到“文件打开过多”的情况。基本原因如上所述。但是,遇到这种情况的原因exec(...)是JVM试图创建“管道”文件描述符,该描述符将连接到外部应用程序的标准输入/输出/错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值