`
wang371134086
  • 浏览: 128443 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java.io.IOException: Too many open files

阅读更多

1. 使用ps -ef |grep java   (java代表你程序,查看你程序进程) 查看你的进程ID,记录ID号,假设进程ID为12

2. 使用:lsof -p 12 | wc -l    查看当前进程id为12的 文件操作状况

执行该命令出现文件使用情况为 1052

3. 使用命令:ulimit -a   查看每个用户允许打开的最大文件数


 

发现系统默认的是open files (-n) 1024,问题就出现在这里。

4. 在系统文件/etc/security/limits.conf中修改这个数量限制,

在文件中加入内容:

* soft nofile 65536

* hard nofile 65536

这样就修改了最大文件数量

ulimit -n 4096

这种网上说的方法,用户重新登录后就会回到默认值,不要用这种方法。

 

可能原因:

1.检查了一下程序,可能是由于用了许多FileInputStream,使用完后没有fileInputStream.close();造成打开的文件没有及时关闭

2.Linux,Aix,Unix系统都有默认打开文件数目最大的限制,使用 ulimit –a 查看每个用户允许打开的最大文件数,如果没有设置,系统默认是打开1024个文件。

root用户可以修改etc/security/limits.conf

加入

*  soft nofile 1024 
*  hard nofile 4096

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics