像呵护你女朋友一样优化你的nginx系统,给她配置防盗链保护她的安全

2023-12-12 22:45

本文主要是介绍像呵护你女朋友一样优化你的nginx系统,给她配置防盗链保护她的安全,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 nginx系统如何隐藏版本号

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

1.1隐藏版本号1(修改配置文件)

修改配置文件:vim /usr/local/nginx/conf/nginx.conf

重启服务并查看版本号

1.2隐藏版本号2(修改源码文件)

1.进入rpm包目录修改版本号和服务类型

vim /opt/nginx-1.22.0/src/core/nginx.h

2.重新配置编译环境,编译并安装

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

3.修改配置文件,显示版本号

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

4.重启服务并登录查看版本号是否更改

2 修改nginx用户与组

修改配置文件vim /usr/local/nginx/conf/nginx.conf

重启服务查看主进程由root创建,子进程由nginx创建

3 缓存时间

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

修改配置文件设定缓存时间

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

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

4 日志切割

编写脚本

vim /opt/fenge.sh

添加脚本执行权限,crontab -e添加周期性计划每小时执行该脚本

5 连接超时

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

修改nginx配置文件设置长连接时间
vim /usr/local/nginx/conf/nginx.conf

5 更改进程数

在高并发场景,需要启动更多的Nginx进程以保证快速响应,以处理用户的请求,避免造成阻塞
cat /proc/cpuinfo | grep -c "physical id" #查看cpu核数
ps aux | grep nginx #查看nginx主进程中包含几个子进程

修改nginx的配置文件

重启服务查看进程数

6 设置并发数

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

vim /etc/security/limits.conf

7 配置网页压缩

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

cd /usr/local/nginx/html 为网页内容目录
vim index.html 配置nginx网页内容文件
nginx -t检查配置文件是否正确,重启服务

原文件大小为14.1KB

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

8 配置防盗链

修改nginx配置文件配置防盗链

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

准备web源主机192.168.111.8网页配置

cd /usr/local/nginx/html

盗链主机配置

cd /usr/local/nginx/html

测试是否能盗取图片连接

清除防盗链配置再测试,可以显示盗链图片

9 nginx常用内核优化

/etc/sysctl.conf                              内核参数的配置文件
net.ipv4.tcp_sysconkies = 1                   开启SYN cookies 当出现SYN等待队列溢出时启用,启用cookies来处理,可防范少量SYN攻击
net.ipv4.tcp_tw_rease = 1                     开启重用,允许将TIME-WAIT sockets重新用于新的TCP连接
net.ipv4.tcp_tw_recycle = 1                   开启TCP连接中TIME-WAIT sockets的快速回收
net.ipv4.tcp_fin_timeout = 30                 修改系统默认的 TIMEOUT 时间(MSL值),原本是60s
net.ipv4.ip_local_port_range = 1024 65535     外向连接的端口范围
net.ipv4.tcp_max_tw_buckets = 5000            系统同时保持TIME-WAIT的最大数量
net.ipv4.tcp_max_syn_backlog = 8192           系统能接受的tcp半连接的最大队列数
net.core.somaxconn = 10000                    每一个端口最大的 Listen 监听队列的长度
net.ipv4.tcp_keepalive_time = 1200            发送keepalive探测包消息的频率
​
net.ipv4.tcp_syncookies = 1 

10 内核限制文件

/etc/security/limits.conf 内核限制文件
*     soft     noproc            65535      打开的进程数
*     hard     noproc            65535
*     soft     nofile            65535      打开的文件数
*     hard     nofile            65535
*     soft     memlock         unlimited     不做内存锁定
*     hard     memlock         unlimited

11 常用的nginx模块

rewrite                     重写功能
access                      来源控制
ssl                         安全加密
ngx_http_gzip_module        网络传输压缩模块
ngxhttp_proxy_module        模块实现代理
ngx_http_upstream_module    定义后端服务器列表
ngx_cache_purge             实现缓存清除功能
​

12 源码编译安装nginx时,如何启用更多的模块以及禁用不需要的模块?简单描述下你都使用过哪些模块?

执行,/configure脚本时,通过添加 --with-模块名 的方式启用更多模块,通过添加 --without-模块名 的方式禁用不需要的

这篇关于像呵护你女朋友一样优化你的nginx系统,给她配置防盗链保护她的安全的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/486221

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas