Nginx优化与防盗链技术

  在当今互联网时代,网站的性能和安全性变得尤为重要。Nginx作为一种高性能的HTTP和反向代理服务器,因其轻量级、高效能和灵活性而被广泛应用于各类网站和应用中。然而,随着互联网流量的不断增长和网络袭击的日益猖獗,如何优化Nginx服务并有效防止盗链成为了每个网站管理员必须面对的重要课题。

  Nginx的优化不仅仅是为了提升网站的响应速度和用户体验,更是为了在高并发环境下保持服务器的稳定性和可靠性。通过合理的配置和优化,可以显著减少服务器的资源消耗,提高处理请求的效率,从而为用户提供更快速、更稳定的访问体验。

  此外,防盗链技术作为一种保护网站资源的重要手段,能够有效防止其他网站未经授权地引用和使用本网站的资源,避免带宽的浪费和服务器的过度负载。通过配置防盗链,可以确保网站资源的合法使用,保护网站的利益。

  本文将详细介绍Nginx的优化方法和防盗链技术,帮助网站管理员在实际操作中更好地管理和维护Nginx服务器。我们将从隐藏版本号、修改用户与组、配置网页缓存时间、日志切割、设置连接超时等方面入手,逐步深入探讨Nginx的优化策略。同时,我们还将介绍如何通过更改进程数、配置网页压缩、防盗链和FPM参数优化等高级技巧,进一步提升Nginx的性能和安全性。

Nginx服务优


1.1 隐藏版本号
目的:隐藏Nginx的版本号可以有效防止袭击者利用已知bug对特定版本的Nginx进行袭击,从而提高服务器的安全性。

方法:

修改Nginx主配置文件:在Nginx的主配置文件(通常为nginx.conf)中,将server_tokens指令设置为off。这样可以在HTTP响应头中隐藏Nginx的版本信息。

server_tokens off;

修改Nginx源码文件:如果需要更彻底地隐藏版本信息,可以修改Nginx的源码文件。在src/http/ngx_http_header_filter_module.c文件中,找到ngx_http_server_string和ngx_http_server_full_string变量,将其值修改为自定义字符串,然后重新编译Nginx。

static u_char ngx_http_server_string[] = "Server: MyServer" CRLF;
static u_char ngx_http_server_full_string[] = "Server: MyServer" CRLF;

1.2 修改用户与组

目的:通过修改Nginx运行的用户与组,可以实现对网站文件读取的访问控制,增强服务器的安全性。

方法:

编译安装时指定用户与组:在编译安装Nginx时,可以通过–user和–group参数指定Nginx运行的用户与组。

./configure --user=nginx --group=nginx

修改Nginx配置文件:在Nginx的主配置文件中,通过user指令指定Nginx运行的用户与组。

user nginx nginx;

1.3 配置网页缓存时间

目的:通过配置网页缓存时间,可以加快用户访问速度,减少重复请求,从而提高服务器的性能。

方法:在Nginx配置文件中,通过expires指令设置缓存时间。可以根据不同的文件类型设置不同的缓存时间。

location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {
      expires 30d;
  }

1.4 日志切割

目的:通过定期切割日志文件,可以方便监控和分析,避免日志文件过大影响服务器性能。

方法:

编写日志切割脚本:编写一个脚本,使用mv命令将当前日志文件重命名为带有日期的文件,然后使用kill -USR1信号通知Nginx重新打开日志文件。

#!/bin/bash
  log_path="/var/log/nginx"
  mv $log_path/access.log $log_path/access_$(date +%Y%m%d).log
  mv $log_path/error.log $log_path/error_$(date +%Y%m%d).log
  kill -USR1 `cat /var/run/nginx.pid`

设置计划任务:使用crontab设置计划任务,定期执行日志切割脚本。

0 0 * * * /path/to/logrotate.sh

1.5 设置连接超时

目的:通过设置连接超时,可以避免资源浪费,控制连接访问时间,提高服务器的性能。

方法:在Nginx配置文件中,通过keepalive_timeout和其他超时参数设置连接超时。

keepalive_timeout 65;
client_header_timeout 10;
client_body_timeout 10;
send_timeout 10;

2. Nginx深入优化

2.1 更改进程数

目的:在高并发环境中,通过合理设置Nginx的工作进程数,可以显著提高服务器的响应速度和处理能力。

方法:

修改worker_processes参数:在Nginx的主配置文件中,通过worker_processes指令设置工作进程数。通常建议将其设置为服务器CPU核心数或其倍数,以充分利用多核CPU的性能。

worker_processes auto;

使用auto参数可以让Nginx自动检测并设置为CPU核心数。

2.2 配置网页压缩

目的:通过启用网页压缩,可以显著减少传输的数据量,节约带宽,提高用户访问速度。

方法:

启用gzip压缩:在Nginx配置文件中,通过gzip指令启用并配置压缩功能。

gzip on;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
gzip_min_length 1000;
gzip_comp_level 5;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_vary on;

gzip on;:启用gzip压缩。
gzip_types:指定需要压缩的文件类型。
gzip_min_length:设置启用压缩的最小文件长度。
gzip_comp_level:设置压缩级别,范围为1-9,数字越大压缩率越高,但CPU消耗也越大。
gzip_buffers:设置用于存储压缩结果的缓冲区大小。
gzip_http_version:指定启用gzip压缩的HTTP协议版本。
gzip_vary:在响应头中添加Vary: Accept-Encoding,以便代理服务器根据客户端的Accept-Encoding头进行缓存。

2.3 配置防盗链
目的:通过配置防盗链,可以有效防止其他网站未经授权地引用和使用本网站的资源,保护网站的带宽和服务器资源。

方法:

使用valid_referers指令:在Nginx配置文件中,通过valid_referers指令设置允许访问的Referer。

location ~* \.(gif|jpg|jpeg|png|css|js)$ {
      valid_referers none blocked server_names *.example.com;
      if ($invalid_referer) {
          return 403;
      }
  }

none:允许没有Referer头的请求。
blocked:允许Referer头被防火墙或代理服务器屏蔽的请求。
server_names:允许Referer头与服务器名称匹配的请求。
*.example.com:允许Referer头为指定域名的请求。
if ($invalid_referer):如果Referer头不在允许列表中,则返回403 Forbidden状态码。

2.4 FPM参数优化
目的:通过优化PHP-FPM(FastCGI Process Manager)参数,可以提高PHP脚本的处理速度和效率,减少服务器的负载。

方法:

调整FPM参数:在PHP-FPM配置文件(通常为www.conf)中,调整以下参数:

pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500

pm:设置进程管理模式,dynamic表示动态管理进程数。
pm.max_children:设置最大子进程数。
pm.start_servers:设置启动时的子进程数。
pm.min_spare_servers:设置最小空闲子进程数。
pm.max_spare_servers:设置最大空闲子进程数。
pm.max_requests:设置每个子进程在重启之前可以处理的最大请求数。

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/12204

(0)
凯影的头像凯影
上一篇 2024年6月26日 下午3:07
下一篇 2024年6月27日 下午3:17

相关推荐

  • 查看调整cpu频率及模式

    使用cpufrequtils查看调整cpu频率及模式 cpufrequtils是一个查看和修改CPU频率GHz的工具有些物理服务器使用默认频率进行运行,这时可以使用该工具进行就该CPU的核心频率 安装: 使用: cpufreq-info 查看当前cpu状态 参数: 参数 值 说明 -c CPU序号 查看所指定cpu状态 -f 查看cpu当前频率 -l 查看c…

    2023年11月3日
    1.3K00
  • frp配置多端口内网穿透?frp多端口怎么配置?

    FRP内网穿透应用场景:本地Web服务外网访问、本地开发微信、本地联调支付宝\微信支付、TCP/UDP端口转发 在本机开发好的网站想让客户测试不在需要上传到服务器上面,使用FRP内外网穿透轻松解决;微信开发也不需要在上传到服务器,使用免费FRP内网穿透服务器帮您解决80端口问题,实现微信服务器直接访问到您本机web服务。 使用frp作为内网穿透的时候,有时候…

    2024年5月10日
    1.4K00
  • VMware vSphere中三种磁盘规格(厚置备延迟置零\厚置备置零\Thin Provision)

    在VMware vSphere中,不管是以前的5.1版本,或者是现在的6.5版本,创建虚拟机时,在创建磁盘时,都会让选择磁盘的置备类型,如下图所示,分为: (1)厚置备延迟置零; (2)厚置备置零; (3)Thin Provision(精简置备)。 在创建虚拟机时,可以选择这三种类型的其中一种,如下图所示 这三种类型的磁盘,每一种类型的磁…

    2023年8月11日
    1.1K00
  • 二进制安装MySQL

    Yum/rpm包安装,简单、快速、无法定制化、新手推荐使用 二进制安装,解压缩后直接简单配置即可使用,速度较快,专业DBA常用 源码编译安装,特点是可以定制化安装需求,缺点过程较为复杂 二进制安装 创建mysql用户 因为这个用户只是用来进行管理,为了系统安全,配置无登录权限 下载mysql二进制软件包(本案例为mysql5.7.33版本) 创建tools目…

    2022年6月24日
    1.6K00
  • 解决Composer Installing dependencies from lock file

    1、问题描述 2、原因 这是因为不匹配composer.json要求的版本。提示我的PHP 7版本太高,不符合composer.json需要的版本,但是在PHP 7下应该也是可以运行的,composer可以设置忽略版本匹配。 3、解决方案 composer install –ignore-platform-reqs 或者 composer update -…

    2023年2月14日
    1.8K00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信