问题
我们在使用nginx等软件的时候会报如下错误
- 重启时:
22/12/31 18:56:02 [warn] 1799#1799: 10240 worker_connections exceed open file resource limit: 1024
- 正常反代报错:
accept() failed (24: Too many open files)
原因是因为超过了linux的最大打开文件数目
解决办法
临时办法
ulimit -n 65536
,当然重启就失效了
永久解决办法
- 修改
/etc/security/limits.conf
文件,添加:
* soft nofile 204800
* hard nofile 204800
* soft nproc 204800
* hard nproc 204800
- 修改
/etc/pam.d/login
,增加:
session required pam_limits.so
需要注意,很多文章只有第一步,针对不同版本,第二步也是要做的。
nginx特别注意
如果是nginx,还需要注意这里,否则还是会报错,在/lib/systemd/system/nginx.service
的[Service]
段,增加:LimitNOFILE=100000
检查
- 重启后,使用
ulimit -n
以及ulimit -a
查看 - 对于nginx,我们使用以下方法:
- 首先
ps -ef
找到nginx的一个work process的pid,假设是1783 - 使用
cat /proc/1783/limits
查看,如下说明OK了[root@nginx-31 ~]# cat /proc/1891/limits Limit Soft Limit Hard Limit Units Max cpu time unlimited unlimited seconds Max file size unlimited unlimited bytes Max data size unlimited unlimited bytes Max stack size 8388608 unlimited bytes Max core file size 0 unlimited bytes Max resident set unlimited unlimited bytes Max processes 63445 63445 processes Max open files 100000 100000 files Max locked memory 65536 65536 bytes Max address space unlimited unlimited bytes Max file locks unlimited unlimited locks Max pending signals 63445 63445 signals Max msgqueue size 819200 819200 bytes Max nice priority 0 0 Max realtime priority 0 0 Max realtime timeout unlimited unlimited us
- 另外记得调整events中的数值:
events { worker_connections 100000; }
- 首先