Nginx 优化与防盗链

news/2025/1/2 1:16:06/

目录

----------------隐藏版本号-------------------

方法一:修改配置文件方式

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

----------------修改用户与组-------------------

----------------缓存时间-------------------

----------------日志切割-------------------

----------------连接超时-------------------

----------------更改进程数-------------------

----------------配置网页压缩-------------------

 ----------------配置防盗链-------------------


----------------隐藏版本号-------------------

可以使用 Fiddler 工具抓取数据包,查看 Nginx版本,
也可以在 CentOS 中使用命令 curl -I http://192.168.80.10 显示响应报文首部信息。
curl -I http://192.168.80.10

方法一:修改配置文件方式

vim /usr/local/nginx/conf/nginx.conf
http {include       mime.types;default_type  application/octet-stream;server_tokens off;                                #添加,关闭版本号......
}

 

systemctl restart nginx
curl -I http://192.168.110.60

 

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

vim /opt/nginx-1.12.0/src/core/nginx.h
#define NGINX_VERSION "1.1.1"                     #修改版本号
#define NGINX_VER "IIS" NGINX_VERSION             #修改服务器类型cd /opt/nginx-1.12.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make installvim /usr/local/nginx/conf/nginx.conf
http {include       mime.types;default_type  application/octet-stream;server_tokens on;......
}
systemctl restart nginx
systemctl restart nginx

 


----------------修改用户与组-------------------

vim /usr/local/nginx/conf/nginx.conf
user nginx nginx;                #取消注释,修改用户为 nginx ,组为 nginx

 

systemctl restart nginx
ps aux | grep nginx


主进程由root创建,子进程由nginx创建

 


----------------缓存时间-------------------

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

vim /usr/local/nginx/conf/nginx.conf
http {
......server {...... location / {root html;index index.html index.htm;}location ~ \.(gif|jpg|jepg|png|bmp|ico)$ {         #加入新的 location,以图片作为缓存对象root html;expires 1d;                                    #指定缓存时间,1天}
......}
}
http://www.192.168.110.60/index.html
systemctl restart nginx

 

在Linux系统中,打开火狐浏览器,右击点查看元素
选择 网络 ---> 选择 HTML、WS、其他 
访问 http://192.168.110.60/game.jpg ,双击200响应消息查看响应头中包含 Cahce-Control:max-age=86400 表示缓存时间是 86400 秒。也就是缓存一天的时间,一天之内浏览器访问这个页面,都是用缓存中的数据,而不需要向 Nginx 服务器重新发出请求,减少了服务器的使用带宽。


----------------日志切割-------------------

vim /opt/rizhi.sh
#!/bin/bash
# Filename: rizhi.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 chmod +x /opt/fenge.sh
/opt/fenge.sh
ls /var/log/nginx
ls /usr/local/nginx/logs/access.log 
crontab -e
0 1 * * * /opt/rizhi.sh

-----------------------------------------------------小知识---------------------------------------------------------
在linux操作系统中,每个文件都有很多的时间参数,其中有三个比较主要,分别是ctime,atime,mtime

ctime(status time):
当修改文件的权限或者属性的时候,就会更新这个时间,ctime并不是create time,更像是change time,
只有当更新文件的属性或者权限的时候才会更新这个时间,但是更改内容的话是不会更新这个时间。

atime(accesstime):
当使用这个文件的时候就会更新这个时间。

mtime(modification time):
当修改文件的内容数据的时候,就会更新这个时间,而更改权限或者属性,mtime不会改变,这就是和ctime的区别。


----------------连接超时-------------------

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

vim /usr/local/nginx/conf/nginx.conf
http {
...... keepalive_timeout 60 60;keepalive_requests 10000;client_header_timeout 80;client_body_timeout 80;
...... 
}
systemctl restart nginx

keepalive_timeout
指定KeepAlive的超时时间(timeout)。指定一个长连接最多可以保持多长时间,服务器将会在这个时间后关闭连接。 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)。


----------------更改进程数-------------------

在高并发场景,需要启动更多的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#将每个worker子进程与特定CPU物理核心绑定,提升cpu利用率,进而提升性能。避免同一个worker子进程在不同的CPU核心上切换或者多个进程跑在一个CPU上,缓存失效,降低性能。
systemctl restart nginx


----------------配置网页压缩-------------------

Nginx的ngx_http_gzip_module压缩模块提供对文件内容压缩的功能
允许Nginx服务器将输出内容在发送客户端之前进行压缩,以节约网站带宽,提升用户的访问体验,默认已经安装
可在配置文件中加入相应的压缩功能参数对压缩性能进行优化

vim /usr/local/nginx/conf/nginx.conf
http {
...... gzip on;                         #取消注释,开启gzip压缩功能gzip_min_length 1k;              #最小压缩文件大小gzip_buffers 4 64k;              #压缩缓冲区,大小为4个64k缓冲区gzip_http_version 1.1;           #压缩版本(默认1.1,前端如果是squid2.5请使用1.0)gzip_comp_level 6;               #压缩比率gzip_vary on;                    #支持前端缓存服务器存储压缩页面gzip_types text/plain text/javascript application/x-javascript text/css text/xml application/xml application/xml+rss image/jpg image/jpeg image/png image/gif application/x-httpd-php application/javascript application/json;        #压缩类型,表示哪些网页文档启用压缩功能
...... 
}
cd /usr/local/nginx/html

先将game.jpg文件传到/usr/local/nginx/html目录下

vim index.html
...... 
<img src="game.jpg"/>                #网页中插入图片
</body>
</html>
systemctl restart nginx

在Linux系统中,打开火狐浏览器,右击点查看元素
选择 网络 ---> 选择 HTML、WS、其他 
访问 http://192.168.110.60,双击200响应消息查看响应头中包含 Content-Encoding: gzip

 ----------------配置防盗链-------------------

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 页面。

网页准备:
Web源主机(192.168.110.60)配置:
cd /usr/local/nginx/html
将game.jpg、error.png文件传到/usr/local/nginx/html目录下

vim index.html
...... 
<img src="game.jpg"/>
</body>
</html>

 


http://www.ppmy.cn/news/172670.html

相关文章

GB28181-2016 协议(一)

文章目录 SIP 协议注册注册信令消息示范基于数字证书的双向认证注册基于数字证书的双向认证注册的消息示范 注销注销协议消息示范 实时音视频点播实时音视频点播命令流程客户端主动发起消息示范 第三方呼叫控制第三方呼叫实时点播消息示范 媒体流保活机制 SIP 协议 注册 注册信…

Transformer12

什么都不说了 都12级了~~ 通过设计的中间原型挖掘Transformer并采取迭代的方式使用中间原型来聚合来自于支持图像的确定性类型信息和查询图像的自适应的类别信息。方法简单但却高效&#xff0c;该方法在两个小样本语义分割基准数据集上大大优于以前的最新结果。 本文简要介绍关…

Transformer20

20也这么快来了 CLIPPO 是一种统一的模型&#xff0c;用单个编码器和对比损失来执行图像、文本和多模态任务&#xff0c;优于传统的 NLP 基线和之前基于像素的掩码语言模型。 近年来&#xff0c;基于 Transformer 的大规模多模态训练促成了不同领域最新技术的改进&#xff0c…

GB28181国标协议

GB28181协议解析 GB28181主要解决&#xff1a;不同平台之间的对接和互通问题。 协议属于应用层的协议&#xff0c;是国内多家厂家联合制定的一套标准。 国标基于SIP&#xff08;会话发起协议或会话初始化协议&#xff09; 各厂家之间GB28181协议的差别&#xff1a; 1.查询录像…

C++ 学习 ::【基础篇:14】:C++ 类的基本成员函数:析构函数的作用 及 自定义析构函数情形

本系列 C 相关文章 仅为笔者学习笔记记录&#xff0c;用自己的理解记录学习&#xff01;C 学习系列将分为三个阶段&#xff1a;基础篇、STL 篇、高阶数据结构与算法篇&#xff0c;相关重点内容如下&#xff1a; 基础篇&#xff1a;类与对象&#xff08;涉及C的三大特性等&#…

18B20详解

特点 独特的一线接口&#xff0c;只需要一条口线通信 多点能力&#xff0c;简化了分布式温度传感应用 无需外部元件 可用数据总线供电&#xff0c;电压范围为3.0 V至5.5 V 无需备用电源 测量温度范围为-55 C至125 ℃ 。华氏相当于是-67 F到257华氏度 -10 C至85 C范围内精度…

0805封装尺寸/0402封装尺寸/0603封装尺寸/1206封装尺寸

0805封装尺寸/0402封装尺寸/0603封装尺寸/1206封装尺寸 封装尺寸与功率关系&#xff1a;   0201 1/20W   0402 1/16W   0603 1/10W   0805 1/8W   1206 1/4W 封装尺寸与封装的对应关系 04021.0mmx0.5mm   06031.6mmx0.8mm   08052.0mmx1.2mm   12063.…

天宝R10不开机/天宝接收机不进系统/天宝R10的常见故障

天宝R10 GPS常见故障和问题包括&#xff1a; GPS信号不稳定或无信号&#xff1a;这可能是由于信号遮挡、卫星位置变化、设备位置不正确或天线故障等原因导致的。解决方法包括调整设备位置、更换天线或更新地图软件。 地图不准确或过时&#xff1a;这可能是由于地图数据不完整或…