最近,网站一到高峰期,CPU就会飙升到100%,但内存,IO,网络等一切正常,Google了一下,有可能是ulimit的问题,马上查看文件句柄数限制
ulimit -n
得到的结果是:1024,这个值对生产中的服务显得偏小。
网上给出的解决方案,大部分是直接输入
ulimit -SHn 51200 # 51200可自己根据应用调整
此法缺点很明显,一旦退出登陆,设置就失效了。
也有说直接把该命令写到/etc/rc.d/rc.local中的,今天找到一个正确的做法
1.打开/etc/f,里面有很详细的注释,找到如下设置(如果没有就插入)
* soft nofile 51200
* hard nofile 51200
2.编辑/etc/pam.d/common-session,加入一行
session required pam_limits.so
3.编辑/etc/profile,加入
ulimit -SHn 51200
重启服务器,再次登陆,查看句柄数,已经正确设置为51200。
如果有碰到类似情况,可以检查一下看看是不是文件句柄数设置太小引起的。
对于nginx中有二种改法:
user www www;
worker_processes 4;
worker_rlimit_nofile 65535;
error_log logs/nginx_error.log crit;
events
{
use epoll;
worker_connections 10240;
}
2.系统级别:
vi /etc/f
...
* soft nofile 65535
*hard nofile 65535
ulimit -n
65535
############################
先说解决方案:
sudo vi /etc/pam.d/su
增加pam_limits.so模块引用
session required pam_limits.so
而后设置账号对应的打开文件数限制,建议为 * (所有账户)
编辑 sudo vi /etc/f 文件
* soft nofile 4084
* hard nofile 4084
ok了,reboot一下吧,然后通过 ulimit -a 就能看到生效了
本文发布于:2024-02-03 04:11:57,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170690471648570.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |