Nginx深度优化

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx深度优化相关的知识,希望对你有一定的参考价值。

  1. 隐藏版本号
  2. 修改用户与组
  3. 网页缓存时间
  4. 日志切割
  5. 连接超时
  6. 更改进程数
  7. 网页压缩
  8. 防盗链
  9. FPM参数优化

一、隐藏版本号

1.在centos7系统中通过curl命令查看

curl -I http://192.168.100.26

技术分享图片

2.修改nginx.conf配置文件,在http{}内添加server_tokens off;语句

技术分享图片

3.重启nginx

killall -1 nginx

4.使用curl命令查看验证

curl -I http://192.168.100.26

技术分享图片


二、修改用户与组

Nginx运行时进程需要有用户和组的支持,用以实现对网站文件读取时进行访问控制。主进程由root创建,子进程由指定的用户与组创建,默认为nobody。

1.编译nginx时指定用户与组

./configure
--prefix=/usr/local/nginx
--user=nginx
--group=nginx
--with-http_stub_status_module

2.修改nginx配置文件指定用户与组

vim /usr/local/nginx/conf/nginx.conf

技术分享图片

3.重启nginx

killall -1 nginx

4.查看nginx进程信息(主进程root用户,子进程nginx用户)

ps aux | grep nginx

技术分享图片


三、网页缓存时间

当Nginx将网页数据放回给客户端后,可以设置缓存时间,以便日后进行重复请求访问,以加快访问速度、同时减轻服务器压力,一般对静态资源进行设置,对动态网页不要设置缓存时间。

1.下面对网站的图片进行指定缓存时间设置

技术分享图片

2.修改nginx配置文件,指定缓存时间为1天

vim /usr/local/nginx/conf/nginx.conf

location ~.(gif|jpg|jepg|png|bmp|ico)$ {
root html;
expires 1d;
}

技术分享图片

3.重启nginx

killall -1 nginx

4.Fiddler工具进行抓包验证

技术分享图片


四、日志切割

Nginx通过nginx的信号控制功能脚本来实现日志的自动切割,并将脚本加入到Linux的计划性任务中,让脚本在每天固定的时间执行,得以实现日志切割功能。

1.编写fenge.sh脚本

vim /opt/fenge.sh

#!/bin/bash
#Filename:fenge.sh
d=$(date -d "-1 day" "+%Y%m%d") #显示一天前的时间
logs_path="/var/log/nginx"
pid_path="/usr/local/nginx/logs/nginx.pid"
[ -d $logs_path ] || mkdir -p $logs_path
mv /usr/local/nginx/logs/access.log ${logs_path}/test.com-access.log-$d
kill -USR1 $(cat $pid_path) #创建新日志文件
find $logs_path -mtime +30 | xargs rm -rf #删除30天前的日志文件

2. 为脚本赋予执行权限

chmod +x /opt/fenge.sh

3.执行脚本,测试日志文件是否分割成功

. /fenge.sh

技术分享图片

4.添加计划性任务

crontab -e

#每日凌晨1:00执行脚本
0 1 * /opt/fenge.sh


五、连接超时

一般网站中,为了避免同一个客户长时间占用连接,造成资源浪费,可设置相应的连接超时参数,实现对连接访问时间的控制。

1. 修改nginx.conf配置文件

vim /usr/local/nginx/conf/nginx.conf

技术分享图片

2.重启nginx

killall -1 nginx

3.对网站进行访问,并使用Fiddler工具进行抓包验证

技术分享图片


六、更改进程数

在高并发环境中,需要启动更多的Nginx进程以保证快速响应,用以处理用户的请求,避免造成阻塞。

1.查看ngixn运行进程的个数

cat /proc/cpuinfo | grep -c "physical"

2.修改nginx.conf配置文件

vim /usr/local/nginx/conf/nginx.conf

技术分享图片

3.重启nginx

killall-1 nginx

4.查看nginx进程数

ps aux | grep nginx

技术分享图片


七、网页压缩

Nginx服务器将输出内容压缩后进行传输,以节约网站的带宽,提升用户的访问体验,默认已经安装了该模块。

1.修改nginx.conf配置文件

vim /usr/local/nginx/conf/nginx.conf

gzip on;
gzip_buffers 4 64k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_min_length 1k;
gzip_vary on;
gzip_types text/plain text/javascript application/x-javascript text/css text/xml application/xml application/xml+rss text/jpg text/png;

2.重启nginx

killall -1 nginx

3.创建一个大于1KB以上的网页文件,然后对其进行访问抓包

curl -I  -H "Accept-Encoding: gzip, deflate" 192.168.100.26/

技术分享图片


八、防盗链

在网站中,一般都要配置防盗链功能,以避免网站内容被非法盗用,造成经济损失,也避免了流量的浪费。

1.修改nginx.conf配置文件

vim /usr/local/nginx/conf/nginx.conf

location ~.(jpg|gif|swf)$ { #匹配.jpg 、.gif 、或 .swf结尾的文件
valid_referers none blocked
.abc.com abc.com; #信任域名站点
if ( $invalid_referer ) {
rewrite ^/ http://www.abc.com/error.png; #重写返回error.png
}
}

2.重启nginx

killall -1 nginx

九、FPM参数优化

Nginx的php解析功能实现是由FPM处理的,为了提高PHP的处理速度,可对FPM模块进行参数的调整。
1.安装带有FPM模块的PHP环境;
2.FPM进程有两种启动方式,由pm参数指定,分别是static和dynamic,前者将产生固定数据的FPM进程,后者将以动态的方式产生FPM进程;

1.修改php-fpm.conf文件

vi php-fpm.conf

pid = run/php-fpm.pid
pm = dynamic #动态方式
pm.max_children=20 #最大启动进程数量为20个
pm.start_servers = 5 #初始启动时进程为5个
pm.min_spare_servers = 2 #最小空闲进程数为2个
pm.max_spare_servers = 8 #最大空闲进程数为8个

以上是关于Nginx深度优化的主要内容,如果未能解决你的问题,请参考以下文章

Nginx深度优化

Nginx深度优化

搭建Nginx服务器及深度优化

搭建Nginx服务器及深度优化

送你80%的面试胜率-Nginx深度优化

nginx的深度学习之部分优化与防盗链配置