文章插图
前面几周,讲过Nginx的日志配置:Nginx | 超详细!Nginx 日志配置实践,然后也讲了Nginx的进程模型,底层原理等:Nginx为什么快到根本停不下来?没看过的可以先看看(链接点击可跳转) 。
例如:Nginx 的进程模型本篇,我们则来讲讲Nginx的几种性能优化方式 。
目录[-]
文章插图
1、Nginx运行工作进程数量Nginx运行工作进程个数一般设置CPU的核心或者核心数x2 。如果不了解cpu的核数,可以top命令之后按1看出来,也可以查看/proc/cpuinfo文件 grep ^processor /proc/cpuinfo | wc -l 。
[root@lx~]# vi/usr/local/nginx1.10/conf/nginx.confworker_processes 4;[root@lx~]# /usr/local/nginx1.10/sbin/nginx-s reload[root@lx~]# ps -aux | grep nginx |grep -v greproot 9834 0.0 0.0 47556 1948 ? Ss 22:36 0:00 nginx: master processnginxwww 10135 0.0 0.0 50088 2004 ? S 22:58 0:00 nginx: worker processwww 10136 0.0 0.0 50088 2004 ? S 22:58 0:00 nginx: worker processwww 10137 0.0 0.0 50088 2004 ? S 22:58 0:00 nginx: worker processwww 10138 0.0 0.0 50088 2004 ? S 22:58 0:00 nginx: worker process
2、Nginx运行CPU亲和力比如4核配置:
worker_processes 4;worker_cpu_affinity 0001 0010 0100 1000
比如8核配置:【Nginx在高并发下的性能优化点!有这篇就够了】
worker_processes 8;worker_cpu_affinity 00000001 00000010 00000100 0000100000010000 00100000 01000000 10000000;
worker_processes最多开启8个,8个以上性能提升不会再提升了,而且稳定性变得更低,所以8个进程够用了 。3、Nginx最大打开文件数
worker_rlimit_nofile 65535;
这个指令是指当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(ulimit -n)与nginx进程数相除,但是nginx分配请求并不是那么均匀,所以最好与ulimit -n的值保持一致 。注:文件资源限制的配置可以在/etc/security/limits.conf设置,针对root/user等各个用户或者*代表所有用户来设置 。
* soft nofile 65535* hard nofile 65535
用户重新登录生效(ulimit -n)4、Nginx事件处理模型
events {use epoll;worker_connections 65535;multi_accept on;}
nginx采用epoll事件模型,处理效率高 。work_connections是单个worker进程允许客户端最大连接数,这个数值一般根据服务器性能和内存来制定,实际最大值就是worker进程数乘以work_connections 。
实际我们填入一个65535,足够了,这些都算并发值,一个网站的并发达到这么大的数量,也算一个大站了!
multi_accept 告诉nginx收到一个新连接通知后接受尽可能多的连接,默认是on,设置为on后,多个worker按串行方式来处理连接,也就是一个连接只有一个worker被唤醒,其他的处于休眠状态,设置为off后,多个worker按并行方式来处理连接,也就是一个连接会唤醒所有的worker,直到连接分配完毕,没有取得连接的继续休眠 。当你的服务器连接数不多时,开启这个参数会让负载有一定的降低,但是当服务器的吞吐量很大时,为了效率,可以关闭这个参数 。
5、开启高效传输模式
http {include mime.types;default_type Application/octet-stream;……sendfile on;tcp_nopush on;……}
- Include mime.types :媒体类型,include 只是一个在当前文件中包含另一个文件内容的指令 。
- default_type application/octet-stream :默认媒体类型足够 。
- sendfile on:开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载 。注意:如果图片显示不正常把这个改成off 。
- tcp_nopush on:必须在sendfile开启模式才有效,防止网路阻塞,积极的减少网络报文段的数量(将响应头和正文的开始部分一起发送,而不一个接一个的发送 。)
6、连接超时时间主要目的是保护服务器资源,CPU,内存,控制连接数,因为建立连接也是需要消耗资源的 。
keepalive_timeout 60;tcp_nodelay on;client_header_buffer_size 4k;open_file_cache max=102400 inactive=20s;open_file_cache_valid 30s;open_file_cache_min_uses 1;client_header_timeout 15;client_body_timeout 15;reset_timedout_connection on;send_timeout 15;server_tokens off;client_max_body_size 10m;
推荐阅读
- 漏洞无处不在,3步教你暴力破解ssh服务
- 班主任寄语有哪些?
- 淘宝卖东西收费用吗 淘宝怎么收费用标准
- 淘宝店铺怎么修改自己的经营品类 淘宝主营行业在哪里修改
- 淘宝客审核过多久能开始推广 淘宝分享链接有效期多久
- 可以查到淘宝店的店主信息吗 淘宝店铺主账号在哪里看
- 单宁在黑茶中含量多少,苦荞茶养生
- 茶在手中是风景,你我都是彼此的小心柑
- 南通家纺城在哪 南通家纺城地址
- 新生儿睫毛怎么变长