请选择 进入手机版 | 继续访问电脑版
用户
请注意:社区账号与官网账号不互通,如需登录社区,请在此注册社区账号!
 找回密码
 注册社区账号

QQ登录

只需一步,快速开始

搜索

运行网站出现Too many open files,CentOS 6.x和CentOS 7.x解决方法

使用交流 2017-11-24 12:00 [复制链接] 查看: 270|回复: 3
本帖最后由 奇梦 于 2018-1-8 12:29 编辑

新手常见问题:
有没有安装完Appnode,配置好网站正常运行一段时间出现报错: Too many open files
出现以上报错可以根据安装的CentOS不同版本来解决;出现这个报错是请求的文件数超出了系统默认限制。
首先我们SSH远程服务器,运行 ulimit -a 查看 open files 默认值是多少,如下图:
QQ截图20171124103639.jpg
这里我们看到open files默认是1024,可以通过 ulimit -n 2048 来修改默认值,最大可以调到65535,这种方法只针对当前进程有效,重启后又会恢复到默认1024,下面针对CentOS不同版本修改永久生效的办法;

  CentOS 6.X
1、CentOS 6.X版本中,检查 /proc/sys/fs/file-max 文件来确认最大打开文件数已经被正确设置,如下图:
1.jpg
2. 在 /etc/security/limits.conf 文件中设置最大打开文件数, 添加如下这行
#

* - nofile 8192
2.jpg
"nofile"项有两个可能的限制措施。就是项下的hard和soft,要使修改过得最大打开文件数生效,必须对这两种限制进行设定。 如果使用"-"字符设定, 则hard和soft设定会同时被设定。

  CentOS 7.X
1、在CentOS 7.X的系统中,使用Systemd替代了之前的SysV,因此 /etc/security/limits.conf 文件的配置作用域缩小了一些。limits.conf这里的配置,只适用于通过PAM认证登录用户的资源限制,它对systemd的service的资源限制不生效。登录用户的限制,与上面讲的一样,通过 /etc/security/limits.conf 来配置即可。

对于systemd service的资源限制,如何配置呢?
2、全局的配置,放在文件 /etc/systemd/system.conf /etc/systemd/user.conf ,同时,也会加载两个对应的目录中的所有.conf文件/etc/systemd/system.conf.d/*.conf和/etc/systemd/user.conf.d/*.conf
3.jpg
其中,system.conf是系统实例使用的,user.conf用户实例使用的。一般的sevice,使用system.conf中的配置即可。systemd.conf.d/*.conf中配置会覆盖system.conf。

修改了system.conf后,需要重启系统才会生效。编辑/usr/lib/systemd/system/nginx.service文件,做如下配置:

[Service]
LimitCORE=infinity
LimitNOFILE=100000
LimitNPROC=100000

然后运行如下命令,才能生效。


sudo systemctl daemon-reload
sudo systemctl restart nginx.service

查看一个进程的limit设置:cat /proc/YOUR-PID/limits


点评

给力帖  发表于 2017-11-24 13:33
回复

使用道具 举报

500 发表于 2017-12-28 16:20:34 | 显示全部楼层
支持,不过一般没有设置这么小值的vps了
回复 支持 反对

使用道具 举报

奇梦  楼主| 发表于 2018-1-2 13:16:09 | 显示全部楼层
500 发表于 2017-12-28 16:20
支持,不过一般没有设置这么小值的vps了

哈哈 偶遇代码特工组成员,我用的不是vps 默认值都小
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册社区账号

本版积分规则

温馨提示
为了能您的问题能够尽快得到解决,复杂问题建议您直接提交工单处理。
QQ群:744188

Archiver|手机版|AppNode 用户社区

GMT+8, 2018-1-22 10:05

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回列表