linux句柄数不足的java报错_Linux下Tomcat性能优化--文件句柄数增大

在进行并发性能测试时,遇到Java IOException提示打开的文件过多,原因是Linux默认句柄数限制。解决方案包括:将类打包成jar以减少文件句柄消耗,确保正确关闭Socket,以及调整Linux系统设置,增大文件句柄限制,如在limits.conf中设置nofile参数。这些更改可缓解并发访问时的句柄不足问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在对项目进行性能压力测试时,设置并发量为1000,发现Tomcat控制报错:

java.IOException:打开的文件过多

经搜索,发现是由于Linux默认设置的句柄数为1024,当并发量过大,就不够用了;

原因:

操作系统的中打开文件的最大句柄数受限所致,常常发生在很多个并发用户访问服务器的时候.因为为了执行每个用户的应用服务器都要加载很多文件(new一个socket就需要一个文件句柄),这就会导致打开文件的句柄的缺乏.

解决:

尽量把类打成jar包,因为一个jar包只消耗一个文件句柄,如果不打包,一个类就消耗一个文件句柄.

java的垃圾回收不能关闭网络连接打开的文件句柄,如果没有执行close()(例如:java.net.Socket.close())则文件句柄将一直存在,而不能被关闭.你也可以考虑设置socket的最大打开数来控制这个问题.

对操作系统做相关的设置,增加最大文件句柄数量。

采用增大句柄数的方法解决;

查看当前设置句柄数:ulimit -a

71e24036aedeb4f552a1acc9de6a8171.png

可以看到,open files 为1024, 而且提示了参数为 -n,下面我们修改该值: ulimit -n 65536

再次查看:ulimit -a

dd0cb13cfc885f0fd1fda81db1d45924.png

open files 已经变成我们需要的 65536

不过上述修改方法只是当前生效,如果要永久生效,还是要修改配置文件

在/etc/security/limits.conf 添加 (* 代表所有用户有效,你也可以配置具体的用户名)

* soft nofile 65536

* hard nofile 65536

可复制运行此段:

echo -ne "

* soft nofile 65534

* hard nofile 65534

" >>/etc/security/limits.conf

修改完退出重新登录就生效了,可重新用ulimit -a查看是否生效。

参考链接:https://jameswxx.iteye.com/blog/2096461

http://www.360doc.com/content/12/1116/13/834950_248186612.shtml

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值