nginx配置详解
基本配置详解
-
用户
user nginx ;
-
工作进程,根据硬件调整,大于等于cpu核数
worker_processes 8;
-
错误日志
error_log logs/nginx_error.log crit;
-
pid放置的位置
pid logs/nginx.pid;
-
指定进程可以打开的最大描述符
- 这个指令是指当一个nginx进程打开的最多文件描述符数目,
- 理论值应该是最多打开文件数(ulimit -n)与nginx进程数相除,
- 但是nginx分配请求并不是那么均匀,所以最好与ulimit -n 的值保持一致。
- 现在在linux 2.6内核下开启文件打开数为65535,worker_rlimit_nofile就相应应该填写65535。
- 这是因为nginx调度时分配请求到进程并不是那么的均衡,所以假如填写10240,
- 总并发量达到3-4万时就有进程可能超过10240了,这时会返回502错误。
worker_rlimit_nofile 204800;
事件配置详解
- 使用epoll的I/O 模型
- 补充说明:
与apache相类,nginx针对不同的操作系统,有不同的事件模型
- 标准事件模型 Select、poll属于标准事件模型,如果当前系统不存在更有效的方法,nginx会选择select或poll
- 高效事件模型
- Kqueue:使用于FreeBSD 4.1+, OpenBSD 2.9+, NetBSD 2.0 和 MacOS X. 使用双处理器的MacOS X系统使用kqueue可能会造成内核崩溃。
- Epoll: 使用于Linux内核2.6版本及以后的系统。
- /dev/poll:使用于Solaris 7 11/99+, HP/UX 11.22+ (eventport), IRIX 6.5.15+ 和 Tru64 UNIX 5.1A+。
- Eventport:使用于Solaris 10. 为了防止出现内核崩溃的问题, 有必要安装安全补丁
- 补充说明:
与apache相类,nginx针对不同的操作系统,有不同的事件模型
events
{
use epoll;
-
工作进程的最大连接数量
worker_connections 204800;
-
根据硬件调整,和前面工作进程配合起来用,尽量大,但是别把cpu跑到100%就行 每个进程允许的最多连接数, 理论上每台nginx服务器的最大连接数为worker_processes*worker_connections
-
keepalive超时时间。
keepalive_timeout 60;
-
客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求头的大小不会超过1k, 不过由于一般系统分页都要大于1k,所以这里设置为分页大小。 分页大小可以用命令getconf PAGESIZE 取得。
[root@web001 ~] # getconf PAGESIZE
4096但也有client_header_buffer_size超过4k的情况,但是client_header_buffer_size该值必须设置为“系统分页大小”的整倍数。
client_header_buffer_size 4k;
-
这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存。
open_file_cache max=65535 inactive=60s;
-
这个是指多长时间检查一次缓存的有效信息。
open_file_cache_valid 80s;
-
open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的,
-
如上例,如果有一个文件在inactive时间内一次没被使用,它将被移除。
open_file_cache_min_uses 1;
}