干货!几个 Nginx 性能优化方法

均需修改nginx的配置文件

vi/nginx/conf/nginx.conf

1、worker_processes 工作进程最大连接数

worker 进程数默认为 1 ,单进程最大连接数为1024

每个 worker 进程都是单线程的进程,它们会调用各个模块以实现多种多样的功能

如果这些模块确认不会出现阻塞式的调用,那么有多少CPU内核就应该配置多少个进程

反之,如果有可能出现阻塞式调用,那么需要配置稍多一些的worker进程

例如:如果业务方面会致使 用户请求 大量读取 本地磁盘上的静态资源文件,而且服务器上的内存较小,以至于 大部分的请求 访问 静态资源文件 时,都必须读取磁盘(磁头的寻址是缓慢的),而不是内存中的磁盘缓存,那么磁盘 IO 调用可能会 阻塞 住 worker 进程少量时间,进而导致服务整体性能下降。


运行工作进程个数一般设置CPU的核心或者核心数x2

如果不了解CPU的核数,可以top命令后按1来看


实操

# 编辑ng的配置文件

>vi /usr/local/nginx/conf/nginx.conf

> worker_processes 4;

# 保存退出

# 重新加载ng配置文件

>/usr/local/nginx/sbin/nginx-sreload

# 查看进程情况

> ps -aux | grep nginx |grep -v grep



2、worker_cpu_affinity工作进程绑定CPU内核

假定每一个 worker 进程都是非常繁忙的,如果多个 worker 进程都在抢同一个 CPU,那么这就会出现 同步问题。

反之,如果每一个 worker 进程都独享一个 CPU,就在 内核的调度 策略上实现了完全的 并发。

注意:worker_cpu_affinity 配置仅对 Linux 操作系统有效。

# 如:如果有`2`颗`CPU`内核,就可以进行如下配置

worker_processes2;

worker_cpu_affinity10 01;

# 如:如果有`4`颗`CPU`内核,就可以进行如下配置

worker_processes4;

worker_cpu_affinity1000 0100 0010 0001;

# 如:如果有`8`颗`CPU`内核,就可以进行如下配置

worker_processes8;

worker_cpu_affinity 00000001 00000010 0000010 00000100000010000 00100000 01000000 10000000;

附件:

基本参数优化

server_tokens off;

#关闭在错误页面中的nginx版本号,安全性是有好处的

sendfile on;

#传输文件时发挥作用

tcp_nopush on;

#一个数据包里发送所有头文件

tcp_nodelay on;

#不缓存数据

keepalive_timeout 10; 

#在这个超时时间过后关闭客户端链接

client_header_timeout 10; 

#设置请求头的超时时间

client_body_timeout 10;

#设置请求体的超时时间

reset_timeout_connection on;

#开启关闭不响应的客户端连接功能,释放客户端所占的内存空间

send_timeout 10;

#客户端的响应超时时间。如果在这段时间内,客户端没有读取任何数据,nginx就会关闭连接。

#limit_conn_zone 设置用于保存各种key(比如当前连接数)的共享内存的参数。5m就是5兆字节,这个值应该被设置的足够大以存储(32K5)32byte状态或者(16K5)64byte状态。

limit_conn

#为给定的key设置最大连接数。这里key是addr,我们设置的值是100,也就是说我们允许每一个IP地址最多同时打开有100个连接。

default_type

#设置文件使用的默认的MIME-type。

charset

#设置我们的头文件中的默认的字符集

Gzip压缩优化

gzip_types  

#压缩的文件类型

 text/plain text/css 

 application/json 

 application/x-javascript 

 text/xml application/xml 

 application/xml+rss 

 text/javascript

gzip on;

#采用gzip压缩的形式发送数据

gzip_disable "msie6"

#为指定的客户端禁用gzip功能

gzip_static;

#压缩前查找是否有预先gzip处理过的资源

gzip_proxied any;

#允许或者禁止压缩基于请求和响应的响应流

gzip_min_length  1000;

#设置对数据启用压缩的最少字节数

gzip_comp_level 6;

#设置数据的压缩等级

FastCGI参数优化

fastcgi_cache_path 

/data/ngx_fcgi_cache #缓存路径

levels=2:2 #目录结构等级

keys_zone=ngx_fcgi_cache:512m 

 #关键字区域存储时间

inactive=1d #非活动删除时间

fastcgi_connect_timeout 240; 

#连接到后端fastcgi的超时时间

fastcgi_send_timeout 240; 

#建立连接后多久不传送数据就断开

fastcgi_read_timeout 240; 

#接收fastcgi应答的超时时间

fastcgi_buffer_size 64k; 

#指定读取fastcgi应答缓冲区大小

fastcgi_buffers 4 64k;

#指定本地缓冲区大小(缓冲FaseCGI应答请求)

fastcgi_busy_buffers_size 128k; 

#繁忙时的buffer,可以是fastcgi_buffer的两倍

fastcgi_temp_file_write_size  128k; 

#在写入缓存文件时用多大的数据块,默认是fastcgi_buffer的两倍

fastcgi_cache mingongge;

#开启缓存时指定一个名称

fastcgi_cache_valid 200 302 1h;

#指定应答码200 302 缓存一小时

fastcgi_cache_valid 301 1d; 

#指定应答码301缓存一天

fastcgi_cache_valid any 1m;

#指定其它应答码缓存一月

其它参数优化

open_file_cache

#指定缓存最大数目以及缓存的时间

open_file_cache_valid

#在open_file_cache中指定检测正确信息的间隔时间

open_file_cache_min_uses   

#定义了open_file_cache中指令参数不活动时间期间里最小的文件数

open_file_cache_errors     

#指定了当搜索一个文件时是否缓存错误信息

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$

#指定缓存文件的类型

        {

        expires 3650d;    

           #指定缓存时间

        }

        location ~ .*\.(js|css)?$

        {

        expires 3d;                     

        }

expires有个缺点就是如果更新WEB数据后,用户没有清理缓存,会看到旧的数据,因此建议将时间设置短一点

优化后完整的配置文件

user www; 

pid /var/run/nginx.pid; 

worker_processes auto; 

worker_rlimit_nofile 100000; 

events { 

worker_connections 2048; 

multi_accept on; 

use epoll; 

http { 

server_tokens off; 

sendfile on; 

tcp_nopush on; 

tcp_nodelay on; 

access_log off; 

error_log /var/log/nginx/error.log crit; 

keepalive_timeout 10; 

client_header_timeout 10; 

client_body_timeout 10; 

reset_timedout_connection on; 

send_timeout 10; 

limit_conn_zone $binary_remote_addr zone=addr:5m; 

limit_conn addr 100; 

include /etc/nginx/mime.types; 

default_type text/html; 

charset UTF-8; 

gzip on; 

gzip_disable "msie6"; 

gzip_proxied any; 

gzip_min_length 1000; 

gzip_comp_level 6; 

gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript; 

open_file_cache max=100000 inactive=20s; 

open_file_cache_valid 30s; 

open_file_cache_min_uses 2; 

open_file_cache_errors on; 

include /etc/nginx/conf.d/*.conf; 

include /etc/nginx/sites-enabled/*; 

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容