栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

Nginx配置优化及防盗链

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Nginx配置优化及防盗链

目录

1.隐藏Nginx版本号

法一:修改Nginx配置文件的http模块

法二:修改源码文件,重新编译安装

2.修改用户和组

3.设置网站的缓存时间

4.日志切割

5.设置网络超时时间

6.更改进程数

7.配置防盗链


1.隐藏Nginx版本号

法一:修改Nginx配置文件的http模块

这个字段需要手动写入

完成配置之后,重启服务

 

或者我们可以使用下面的命令查看网址的数据

curl -I IP地址

法二:修改源码文件,重新编译安装

修改配置文件/opt/nginx-1.12.0/src/core/nginx.h

 再进入nginx软件包安装目录/opt/nginx-1.12.0/重新编译安装

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

make && make install

重新编译安装之后,将这一行改成on

 

 我们使用curl命令可以看到,端口号和使用的服务已经被修改

2.修改用户和组

修改配置文件首行

 

 此时nginx服务的属主和属组已经改变

3.设置网站的缓存时间

当Nginx将网页数据返回给客户端后,可设置缓存的时间,以方便在日后进行相同内容的请求时直接返回,避免重复请求,加快了访问速度
一般针对静态网页设置,对动态网页不设置缓存时间

在配置文件server模块中加入如下内容

location ~ .(gif|jpg|jepg|png|bmp|ico)$ { 		     #加入新的 location,以图片作为缓存对象
			root html;
			expires 1d;							     #指定缓存时间,1天
		}

配置完成之后,网页内的图片就会被保留在缓存中一天 ,我们在nginx主页中加入一个图片

4.日志切割

我们可以使用脚本加上定时任务的方式来进行日志的分割

分割脚本

im /opt/fenge.sh
#!/bin/bash
# Filename: fenge.sh
day=$(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}/kgc.com-access.log-$day	#移动并重命名日志文件
kill -USR1 $(cat $pid_path)										#重建新日志文件
find $logs_path -mtime +30 -exec rm -rf {} ;					#删除30天之前的日志文件
#find $logs_path -mtime +30 | xargs rm -rf 

定时任务

crontab -e
0 1 * * * /opt/fenge.sh      #每天一点执行一次脚本

5.设置网络超时时间

HTTP有一个KeepAlive模式,它告诉web服务器在处理完一个请求后保持这个TCP连接的打开状态。若接收到来自同一客户端的其它请求,服务端会利用这个未被关闭的连接,而不需要再建立一个连接。
KeepAlive 在一段时间内保持打开状态,它们会在这段时间内占用资源。占用过多就会影响性能。

设置连接时长

vim /usr/local/nginx/conf/nginx.conf
http {
...... 
    keepalive_timeout 65 180;
    client_header_timeout 80;
    client_body_timeout 80;
...... 
}

 

keepalive_timeout
指定KeepAlive的超时时间(timeout)。指定每个TCP连接最多可以保持多长时间,服务器将会在这个时间后关闭连接。 Nginx的默认值是65秒,有些浏览器最多只保持 60 秒,所以可以设定为 60 秒。若将它设置为0,就禁止了keepalive 连接。
第二个参数(可选的)指定了在响应头Keep-Alive:timeout=time中的time值。这个头能够让一些浏览器主动关闭连接,这样服务器就不必去关闭连接了。没有这个参数,Nginx 不会发送 Keep-Alive 响应头。

client_header_timeout
客户端向服务端发送一个完整的 request header 的超时时间。如果客户端在指定时间内没有发送一个完整的 request header,Nginx 返回 HTTP 408(Request Timed Out)。

client_body_timeout
指定客户端与服务端建立连接后发送 request body 的超时时间。如果客户端在指定时间内没有发送任何内容,Nginx 返回 HTTP 408(Request Timed Out)。

6.更改进程数

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

cat /proc/cpuinfo | grep -c "physical id"      #查看cpu核数
ps aux | grep nginx                            #查看nginx主进程中包含几个子进程
vim /usr/local/nginx/conf/nginx.conf
worker_processes  2;            #修改为核数相同或者2倍
worker_cpu_affinity 01 10;      #设置每个进程由不同cpu处理,进程数配为4时0001 0010 0100 1000

7.配置防盗链

为了防止其他网站盗取我们的网站资源,我们可以在server模块中配置防盗链

vim /usr/local/nginx/conf/nginx.conf
http {
......
    server {
    ......
        location ~* .(jpg|gif|swf)$ {
            valid_referers none blocked *.kgc.com kgc.com;
            if ( $invalid_referer ) {
                rewrite ^/ http://www.kgc.com/error.png;
                #return 403;
            }
        }
    ......
    }
}



~* .(jpg|gif|swf)$ :这段正则表达式表示匹配不区分大小写,以.jpg 或.gif 或.swf 结尾的文件;
valid_referers :设置信任的网站,可以正常使用图片;


none:允许没有http_refer的请求访问资源(根据Referer的定义,它的作用是指示一个请求是从哪里链接过来的,如果直接在浏览器的地址栏中输入一个资源的URL地址,那么这种请求是不会包含 Referer 字段的),如 http://www.kgc.com/game.jpg
我们使用 http://www.kgc.com 访问显示的图片,可以理解成 http://www.kgc.com/game.jpg 这个请求是从 http://www.kgc.com 这个链接过来的。


blocked:允许不是http://开头的,不带协议的请求访问资源; 


*.kgc.com:只允许来自指定域名的请求访问资源,如 http://www.kgc.com

if语句:如果链接的来源域名不在valid_referers所列出的列表中,$invalid_referer为true,则执行后面的操作,即进行重写或返回 403 页面。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/865279.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号