一、产生原因

too many open files这个问题主要指的是进程企图打开一个句柄,但是现在进程打开的句柄已经达到了上限,已经无法打开新句柄了。不过这里的files不单是文件的意思,也包括打开的通讯链接(比如socket),正在监听的端口等等,句柄可以理解为指向这些文件的指针,这个错误通常也可以叫做句柄数超出系统限制。
(1)查看当前系统设置的最大句柄数,命令ulimit -a
image.png
open files那一行就代表系统目前允许单个进程打开的最大句柄数,这里是1024。

(2)查看单个进程所有打开的文件详情
lsof -p 进程id
(3)统计进程打开了多少文件
lsof -p 进程id | wc -l
(4)查询系统中进程占用的句柄数

二、解决方法

1、增大允许打开的文件数——命令方式
ulimit -n 2048
这样就可以把当前用户的最大允许打开文件数量设置为2048了,但这种设置方法在重启后会还原为默认值。
ulimit -n命令非root用户只能设置到4096。
想要设置到更大需要sudo权限或者root用户。

2、增大允许打开的文件数——修改系统配置文件
vim /etc/security/limits.conf
#在最后加入
soft nofile 4096
hard nofile 4096
或者只加入
- nofile 8192
最前的
表示所有用户,可根据需要设置某一用户,例如
roy soft nofile 8192
roy hard nofile 8192
注意”nofile”项有两个可能的限制措施。就是项下的hard和soft。 要使修改过得最大打开文件数生效,必须对这两种限制进行设定。 如果使用”-“字符设定, 则hard和soft设定会同时被设定。