[Linux] nginx防盗链与优化

一、Nginx的页面优化

1.1 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;   #压缩比率 (等级为1-9 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;  #压缩类型,表示哪些网页文档启用压缩功能
}

  重启服务,进行访问测试: 

  1.2  配置Nginx的图片缓存 

Nginx在向客户端返回网页数据时,可以设置缓存时间,以便以后有相同内容的请求时直接返回。 一般来说,它是为静态网页设置的,而没有为动态网页设置缓存时间。

 vim /usr/local/nginx/conf/nginx.conf
http {
.................location ~* \.(png|gif|jpg|jepg|bmp|ico|mp3|mp4)$ {  #匹配任意以以下格式为结尾的文件root html;expires 30m;       #缓存时间设置为30分钟   }
}

重启服务,测试访问:  

 1.3  Nginx的连接超时设置 

HTTP有一个keepalive模式,它告诉web服务器在处理请求后保持TCP连接打开。如果收到来自同一客户端的其他请求,则服务器利用未关闭的连接而不建立另一个连接。

Keepalives保持开放一段时间,并在此期间消耗资源。服用太多会影响性能。

在企业网站上,可以通过设置相应的连接超时参数来控制连接访问时间,避免同一客户长时间占用连接造成资源浪费。您可以更改配置文件nginx.conf,设置keepalive_timeout超时。

vim /usr/local/nginx/conf/nginx.confhttp {...... keepalive_timeout 60 180;       //设置连接超时时间    client_header_timeout 80;client_body_timeout 80;...... }

 指定KeepAlive的超时(超时)。如果指定每个TCP连接可以持续的最长时间,则服务器在此时间之后关闭连接。

Nginx的默认值是65秒,有些浏览器最多只持有60秒,所以可以设置为60秒。如果设置为0,则保持活动状态连接将被禁用。

第二个参数(可选)指定响应标头中keep-Alive:timeout=t ime的时间值。此标头允许您在某些浏览器中主动关闭连接,以便服务器不必关闭连接。没有这个参数,Nginx不会发送Keep-Alive响应头。

 重启服务,访问测试:

 1.4 Nginx的并发设置

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

 查看cpu的核心数,根据核心数来设置工作进程数

 #查看cpu核数cat /proc/cpuinfo |grep processor|wc -l或cat /proc/cpuinfo |grep -c processor或cat /proc/cpuinfo | grep -c "physical id"[root@CXK html]#ps aux | grep nginx

 修改工作进程核心数 :

vim /usr/local/nginx/conf/nginx.confworker_processes  2;        #修改为与CPU核数相同或者autoworker_cpu_affinity 01 10;  #设置每个进程由不同cpu处理,进程数配为4时0001 0010 0100 1000​

测试结果: 

二、Nginx安全 

2.1 查看版本号

   方式一:curl模拟访问获取
curl -I 192.168.136.100

   方式二:浏览器访问查看  

2.2 隐藏版本号  

方法一:修改配置文件,关闭版本号 
 vim /usr/local/nginx/conf/nginx.confhttp {include       mime.types;default_type  application/octet-stream;server_tokens off;      #添加这一行,关闭版本号......}

 测试结果:

方法二:修改源码文件中的版本号,重新编译安装 
cp nginx.h nginx.h.bak
vim /opt/nginx-1.24.0/src/core/nginx.h
#define NGINX_VERSION "1.2.3.4" 					#修改版本号
#define NGINX_VER "apache/" NGINX_VERSION 			#修改服务器类型

修改完配置后切换到Nginx软件包中,进行重新编译安装 :

cd /opt/nginx-1.24.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make install

 

 再次修改主配置文件,打开版本号显示 :

vim /usr/local/nginx/conf/nginx.confhttp {include       mime.types;default_type  application/octet-stream;server_tokens on;......}

   重启服务,进行测试:

 

 三、Nginx的日志分割

  1.编写日志分割脚本 
cd /opt
vim cutlogs.sh#!/bin/bash#nginx 分割日志脚本
#用变量day获取前天日期的时间记录
day=$(date -d "-1 day" "+%Y%m%d")
#获取日志的目录
logs_path="/var/log/nginx"
#获取运行时nginx的进程号
pid_path="/usr/local/nginx/logs/nginx.pid"
#二元表达式,如果前面不成立则执行后面的式子
#前面判断该目录是否存在,后面则表示不存在则自动创建该目录
[ -d $logs_path ] || mkdir -p $logs_path
#将生成的日志按照date生成的时间格式改名并移动到指定的路径中保存
mv /usr/local/nginx/logs/access.log ${logs_path}/access.log-$day
#重新生成一个新的日志
kill -USR1 $(cat $pid_path)
#日志文件清理,将30天前的日志进行清除
find $logs_path -mtime +30 -delete
 2. 执行脚本进行测试

3. 将日志脚本添加至计划性任务 
crontab -e

四、Nginx防盗链 

4.1 Nginx防盗链的设置 

1.修改主配配置文件,添加防盗链设置
 vim /usr/local/nginx/conf/nginx.conf
http {
...........
server{
...........
location ~* \.(jpg|gif|swf|png)$ {root  html;expires 1d;                 valid_referers none blocked *.cxk.com cxk.com;   #设置信任的网站,可以正常使用图片;#*.test.com:只允许来自指定域名的请求访问资源 ;#blocked: 允许不是http://开头的,不带协议的请求访问资源#none: 允许没有http refer的请求访问资源 (根据Referer的定义,它的作用是指示-请求是从哪里链接过来的,如果直接在浏览器的地址栏中输入一个资源的URL地址,那么这种请求是不会包含 Referer 字段的)if ( $invalid_referer ) {   rewrite ^/ http://www.cxk.com/error.jpg;}}
............
}
...............
}

2.在 /var/local/nginx/html 下放置好error.png  

3.进行盗链测试 

  盗链主机html网页设置: 

 4.第三方用户访问盗链主机:

访问前设置:

1.关闭防火墙工具firewalld和selinux

2.将域名对应的IP添加到  /etc/hosts 中 

 五、fpm参数优化

Nginx的PHP解析功能实现如果是交由FPM处理的,为了提高PHP的处理速度,可对FPM模块进行参数的调整。

根据服务器的内存与服务负载,调整FPM模块参数。

 vim /usr/local/php/etc/php-fpm.conf pid = run/php-fpm.pid​vim /usr/local/php/etc/php-fpm.d/www.conf--96行--pm = dynamic                #fpm进程启动方式,动态的--107行--pm.max_children=20          #fpm进程启动的最大进程数--112行--pm.start_servers = 5        #动态方式下启动时默认开启的进程数,在最小和最大之间--117行--pm.min_spare_servers = 2    #动态方式下最小空闲进程数--122行--pm.max_spare_servers = 8    #动态方式下最大空闲进程数​​kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`         #重启php-fpmnetstat -anpt | grep 9000

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/214184.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

web前端之css变量的妙用、通过JavaScrip改变css文件中的属性值、querySelector、setProperty

MENU 效果图htmlJavaScripstylequerySelectorsetProperty 效果图 html <div id"idBox" class"p_r w_680 h_160 b_1s_red"><div id"idItem" class"p_a l_0 t_30 w_100 h_100 bc_rgba_255_00_05 radius_50_"></div> …

HarmonyOS Developer——鸿蒙【构建第一个JS应用(FA模型)】

创建JS工程 JS工程目录结构 构建第一个页面 构建第二个页面 实现页面间的跳转 使用真机运行应用 说明 为确保运行效果&#xff0c;本文以使用DevEco Studio 3.1 Release版本为例&#xff0c;点击此处获取下载链接。 创建JS工程 若首次打开DevEco Studio&#xff0c;请点击…

排序算法-选择/堆排序(C语言)

1基本思想&#xff1a; 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09;的一个元素&#xff0c;存放在序列的起始位置&#xff0c;直到全部待排序的 数据元素排完 。 2 直接选择排序: 在元素集合 array[i]--array[n-1] 中选择关键码最大 ( 小 ) 的数据元素…

《PySpark大数据分析实战》图书上线啦

《PySpark大数据分析实战》图书上线啦 《PySpark大数据分析实战》图书上线啦特殊的日子关于创作关于数据关于Spark关于PySpark关于图书/专栏 《PySpark大数据分析实战》图书上线啦 特殊的日子 不知不觉一转眼入驻CSDN已经满一年了&#xff0c;这真是一个充满意义的特殊的日子&…

《python每天一小段》--12 数据可视化《1》

欢迎阅读《Python每天一小段》系列&#xff01;在本篇中&#xff0c;将使用Python Matplotlib实现数据可视化的简单图形。 文章目录 一、概念&#xff08;1&#xff09;安装matplotlib&#xff08;2&#xff09;数据可视化实现步骤 二、绘制简单的折线图&#xff08;1&#xff…

mysql中NULL值

mysql中NULL值表示“没有值”&#xff0c;它跟空字符串""是不同的 例如&#xff0c;执行下面两个插入记录的语句&#xff1a; insert into test_table (description) values (null); insert into test_table (description) values ();执行以后&#xff0c;查看表的…

Navicat 技术指引 | 连接 GaussDB 分布式

Navicat Premium&#xff08;16.3.3 Windows 版或以上&#xff09;正式支持 GaussDB 分布式数据库。GaussDB 分布式模式更适合对系统可用性和数据处理能力要求较高的场景。Navicat 工具不仅提供可视化数据查看和编辑功能&#xff0c;还提供强大的高阶功能&#xff08;如模型、结…

基于人工智能技术的《量化投资AI系统》集群架构设计与实现

乔总&#xff1a;您好&#xff01; 前些日子你我的共同朋友潘总&#xff0c;推荐您来聊聊将ChatGPT应用于量化投资的合作。在与您及您的团队进行了超过2个多小时的沟通后&#xff0c;恕我直言&#xff0c;不客气地说&#xff0c;感觉您的团队对人工智能技术几乎是空白。为了让…

使用linux CentOS本地部署SQL Server数据库

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;数据结构、Cpolar杂谈 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 &#x1f4cb;前言一. 安装sql server二. 局域网测试连接三. 安装cpolar内网穿透四. 将sqlserver映射…

kubectl获取ConfigMap导出YAML时如何忽略某些字段

前言&#xff1a; 当我们在使用Kubernetes时&#xff0c;常常需要通过kubectl命令行工具来管理资源。有时我们也想将某个资源的配置导出为YAML文件&#xff0c;这样做有助于版本控制和资源的迁移。然而&#xff0c;默认情况下&#xff0c;使用kubectl get命令导出资源配置会包…

JVM 分析GC日志

GC日志参数 -verbose:gc 输出gc日志信息&#xff0c;默认输出到标准输出 -XX:PrintGC 输出GC日志。类似&#xff1a;-verbose:gc -XX:PrintGCDetails 在发生垃圾回收时打印内存回收详细的日志&#xff0c;并在进程退出时输出当前内存各区域分配情况 -XX:PrintGCTimeStam…

基于SpringBoot+uniapp微信小程序校园点餐平台详细设计和实现

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专…

vue3 setup语法糖 多条件搜索(带时间范围)

目录 前言&#xff1a; setup介绍&#xff1a; setup用法&#xff1a; 介绍&#xff1a; 前言&#xff1a; 不管哪个后台管理中都会用到对条件搜索带有时间范围的也不少见接下来就跟着我步入vue的多条件搜索&#xff08;带时间范围&#xff09; 在 Vue 3 中&#xff0c;你…

3接上篇 我的自定义GPTs的改进优化 与物理世界连接成功 GPTs的创建与使用定义和执行特定任务的功能模块 通过API与外部系统或服务的交互

https://blog.csdn.net/chenhao0568/article/details/134875067?spm1001.2014.3001.5502 从服务器日志里看到请求多了一个“location” 23.102.140.123 - - [08/Dec/2023:14:02:20 0800] "GET /getWeather.php?location&locationNewYork HTTP/1.1" 200 337 &…

【基于ESP32无线蓝牙上传电脑Excel透传数据】

【基于ESP32无线蓝牙上传电脑透传数据】 1. 引言2. 环境搭建2.1 硬件准备:2.2 软件准备:2.3. 配置Excel端口接收功能3. 测试代码4. 连接电脑和 ESP324.1 烧录程序4.2 启动蓝牙服务4.3 测试数据透传5. 总结1. 引言 随着物联网技术的发展,越来越多的设备开始支持无线通信,其…

八路达林顿晶体管-ULN2803和ULN2804-笔记

八路达林顿晶体管的介绍 ULN2803示例 BULN2803LV 是专为低压系统设计的大电流达林顿管阵列&#xff0c;电路由八个独立的达林顿管组成&#xff0c;每个达林顿管带有续流二极管&#xff0c;可用于驱动继电器、步进电机等感性负载。单个达林顿管在输入电压低至 1.8V 状态下支持电…

京东数据运营(京东API接口):10月投影仪店铺数据分析

鲸参谋监测的京东平台10月份投影仪市场销售数据已出炉&#xff01; 10月份&#xff0c;环同比来看&#xff0c;投影仪市场销售均上涨。鲸参谋数据显示&#xff0c;今年10月&#xff0c;京东平台投影仪的销量为16万&#xff0c;环比增长约22%&#xff0c;同比增长约8%&#xff1…

2022年第十一届数学建模国际赛小美赛D题野生动物贸易是否应长期禁止解题全过程文档及程序

2022年第十一届数学建模国际赛小美赛 D题 野生动物贸易是否应长期禁止 原题再现&#xff1a; 野生动物市场被怀疑是此次疫情和2002年SARS疫情的源头&#xff0c;食用野生肉类被认为是非洲埃博拉病毒的一个来源。在冠状病毒爆发后&#xff0c;中国最高立法机构永久性地加强了野…

Linux内核上游提交完整流程及示例

参考博客文章&#xff1a; 向linux内核提交代码 - 知乎 一、下载Linux内核源码 通过git下载Linux内核源码&#xff0c;具体命令如下&#xff1a; git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git 实际命令及结果如下&#xff1a; penghaoDin…

【linux系统编程】编辑器gcc/g++

目录 Linux下的编辑器 介绍&#xff1a; 1&#xff0c;编辑器gcc/g 1-1&#xff0c;系统的编译过程 1-2&#xff0c;预处理过程 1-3&#xff0c;编译过程 1-4&#xff0c;汇编过程 1-5&#xff0c;链接过程 Linux下的编辑器 介绍&#xff1a; Linux系统下可支持很多高…