解决Swoole服务报错”Too many open files”文件句柄超出系统限制

发布时间:2022-1-11 10:52

如果在Swoole的日志中遇到了 Too many open files 这种报错,不要慌,在开发 TCP 网络应用的过程中,经常会遇到 Too many open files 这个问题。

这说明你的程序以达到 Linux 所允许的打开文件数上限。需要修改 ulimit 设置

可以使用 lsof 查看进程打开的文件句柄数:

# 将 PID 修改为你要检查的进程ID
lsof -p PID | wc -l

也可以去掉 | wc -l 来检查服务打开了那些文件句柄,未进行关闭。

可以使用 ulimit -n 查看当前设置为多少

[root@shenyan ~]# ulimit -n
100001

如果过小,需要进行调整,Swoole 文档中推荐 ulimit -n 要调整为 100000 甚至更大。

那么如何修改呢?

命令行下执行 ulimit -n 100000 即可修改。

但是需要注意,有时候这种修改方法仅当前终端有效,关闭或者重新开个一个终端就会恢复之前的设置。

这时就需要修改 /etc/security/limits.conf,加入

* soft nofile 262140
* hard nofile 262140
root soft nofile 262140
root hard nofile 262140
* soft core unlimited
* hard core unlimited
root soft core unlimited
root hard core unlimited

修改 limits.conf 文件后,需要重启系统生效。

这样操作完成以后,如果还是报错 Too many open files,那么就可以试试检查运行中的进程限制:

# 将 PID 修改为你要检查的进程ID
cat /proc/PID/limits

如果这里的 Max open files 过小,也是需要进行修改的。

这种情况大多数出现于使用 supervisor 等工具进行管理的时候,supervisor 启动服务默认的 minfds 配置是 1024,所以会出现 Too many open files。

使用 systemd 的话,也是同样的道理,需要修改 LimitNOFILE。如果不设置或者设置为 LimitNOFILE=unlimited(不识别),则默认为 1024。

而这里也要注意设置 LimitNOFILE=infinity 就等于 LimitNOFILE=65536,对于需求 10 万以上文件打开数的人,一定要自行设定。

综上所述,遇到 Too many open files 时的解决方法:

1. ulimit -n

2. supervisor:minfds

3. systemd:LimitNOFILE

Vue3学习笔记之依赖注入Provide/Inject 网站建设

Vue3学习笔记之依赖注入Provide/Inject

Provide / Inject 通常,当我们需要从父组件向子组件传递数据时,我们使用 props。想象一下这样的结构:有一些深度嵌套的组件,而深层的子组件只需要父组件的部分内容。在这种情况下,如果...
Vue3全局实例上挂载属性方法案例讲解 网站建设

Vue3全局实例上挂载属性方法案例讲解

在大多数开发需求中,我们有时需要将某个数据,或者某个函数方法,挂载到,全局实例身上,以便于,在项目全局的任何位置都能够调用其方法,或读取其数据。 在Vue2 中,我们是在 main.js 中 直...