我在/etc/security/limits.conf中的配置是
* soft nofile 60000
* hard nofile 60000我在ubuntu.after中运行nginx重新启动ubuntu,ulimit -n是60000,但是
cat /proc/`ps -elf | grep nginx | grep 'master process' | awk '{print $4}'`/limits| grep 'open files'答案是1024,为什么不是60000?
发布于 2018-03-06 06:34:53
/etc/security/limits.conf在登录时由PAM模块pam_limits.so读取。
但是,当nginx在引导时启动时,它永远不会通过登录过程,因此PAM从来没有机会对nginx进程或它的任何父进程进行任何ulimit更改。
如果您的nginx是由脚本启动的,那么您应该向脚本中添加ulimit命令:
ulimit -H -n 60000
ulimit -S -n 60000如果nginx是由systemd .service文件启动的,请使用systemctl edit nginx.service,并将该行添加到文件的[Service]部分:
LimitNOFILE=60000:60000systemctl edit some.service将自动从[/usr]/lib/systemd树中获取原始服务文件,并将修改后的版本放在/etc/systemd下。/etc/systemd中的任何文件都将覆盖位于[/usr]/lib/systemd树中同名的任何文件。
它还将导致服务配置自动重新加载,因此不需要手动使用systemctl daemon-reload。
https://unix.stackexchange.com/questions/428406
复制相似问题