nginx 优化系列之worker_con…

来源:互联网 发布:同花顺证券行情分析软件 编辑:程序博客网 时间:2024/06/05 07:33
受益匪浅,希望有更好的nginx和apache配置
原文地址:优化系列之worker_connections">nginx 优化系列之worker_connections作者:xubowhucs

nginx.conf

events {

       use epoll;

       worker_connections 8192;

}

增加 worker_connections,测试配置报告:

[warn]: 8192 worker_connections are more than open file resourcelimit: 1024

这需要调整系统的文件描述符 nofile

open file resource limit是linux中process可以打开的文件句柄数量。增加这个数值需要调整两个配置:

第一步, 修改系统最大允许的文件描述符

查看当前的设置:

$ cat /proc/sys/fs/file-max

2390251

或者 

$ sysctl -a

fs.file-max = 2390251

该系统是CentOS 5.x x64版本,安装好后没有做过优化设定, 2390251是其默认值

$ ulimit -n

1024

如果 /proc/sys/fs/file-max小于我们要设定的句柄数量,可以通过:

$echo "2390251" > /proc/sys/fs/file-max

或者修改 /etc/sysctl.conf,在文件中修改fs.file-max的值(没有就创建一条)

修改完后可以通过

$ sysctl -p

使设置生效

2. 文件描述符修改后,需要调整针对用户或者组(user/group)的限制

/etc/security/limits.conf,文件格式为

<domain> <type> <item> <value>

其中<type>为soft或者hard,有些应用会自动把soft限制提升到hard限制,如java,至于nginx,没有看到相关的文档。

如:

* - nofile  8192

表示对所有的用户,文件描述符可以用到 8192, 或者

user_abc  - nofile  8192

表示对用户 user_abc,文件描述符可以用到 8192

3. 有些情况 /etc/security/limits.conf并不会发生作用,如在 init.d中启用的进程,或者daemons运行的进程。

此时比较有效的办法是在init的script中,明确命令 ulimit -n xxxxx

除了在系统中进行设定 nofile(fs.file-max) 值外,可以在 nginx.conf中指定worker_process可以使用的nofile值,如:
#user  nobody;
worker_processes  3;
#error_log  logs/error.log;
#error_log  logs/error.log notice;
error_log  logs/error.log info;
pid       /var/run/nginx.pid;
worker_rlimit_nofile   8192;
events {
       use epoll;
       worker_connections 8192;
}
重新加载nginx配置,使新设定生效。
上面方案还临时减少了另外一个常常出现的错误:

limiting connections by zone "one", client: xxx.xxx.xx.x,server:....

关于此问题的详细描述,会在后续文章中列出。
http://blog.csdn.net/suvi/archive/2010/07/09/5722909.aspx
转自: