共计 1360 个字符,预计需要花费 4 分钟才能阅读完成。
Nginx 提示:Too many open files 这种错误问题的原因是因为 linux 文件系统最大可打开文件数为 1024,而你的 nginx 中的 error.log 出现大量的 Too many open files,说明文件句柄不够用了所以就错误提示出来了。
如果 nginx 的 error.log 出现大量的 Too many open files,说明文件句柄不够用了,这时候我们需要加大系统的文件句柄数和 nginx 的允许最大的连接数。
默认情况下 linux 文 件系统最大可打开文件数为 1024,对于一个应用于生产环境下的服务器来说,这个设置太小,例如在用 nginx 做 web 服务器,当并发达到一定数量时,可以看到 error.log 里出现大量的“Nginx accept() failed (24: Too many open files)”的错误。
正确设置 Linux 的 ulimit - n 的值的步骤如下:
1. 先用命令 ulimit -n 查看目前的值
2. vim /etc/security/limits.conf
建议把下面两项都设置为 65535
* soft nofile 65535
* hard nofile 65535
(前面的 * 星号代表全局,针对所有的用户;nofile 代表文件句柄数量;soft nofile 的值不能超过 hard nofile 的值)
3.vim /usr/local/nginx/conf/nginx.conf
找到 worker_connections,把值调大一些,比如加个 0
4. 重启 Linux 系统
命令:shutdown -r now 表示立即重启
Nginx、Apache 工作原理及 Nginx 为何比 Apache 高效 http://www.linuxidc.com/Linux/2017-03/141896.htm
CentOS 7 下 Nginx 服务器的安装配置 http://www.linuxidc.com/Linux/2017-04/142986.htm
CentOS 上安装 Nginx 服务器实现虚拟主机和域名重定向 http://www.linuxidc.com/Linux/2017-04/142642.htm
CentOS 6.8 安装 LNMP 环境(Linux+Nginx+MySQL+PHP)http://www.linuxidc.com/Linux/2017-04/142880.htm
Nginx 服务的 SSL 认证和 htpasswd 认证 http://www.linuxidc.com/Linux/2017-04/142478.htm
Linux 中安装配置 Nginx 及参数详解 http://www.linuxidc.com/Linux/2017-05/143853.htm
Nginx 日志过滤 使用 ngx_log_if 不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm
CentOS 7.2 下 Nginx+PHP+MySQL+Memcache 缓存服务器安装配置 http://www.linuxidc.com/Linux/2017-03/142168.htm
Nginx 的详细介绍 :请点这里
Nginx 的下载地址 :请点这里
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-05/144109.htm