0

0

记一次LVS/Nginx环境下的访问控制

星夢妙者

星夢妙者

发布时间:2025-06-26 13:06:29

|

953人浏览过

|

来源于php中文网

原创

在偶然中,我注意到 graphite 显示的服务器网卡流量呈现出一种锯齿状的波动,这引起了我的警觉。通过检查 nginx 日志,我发现了有人在周期性地抓取我们的接口数据。这种行为让我无法容忍。

通过对访问日志进行简单的分析,我迅速锁定了可疑的 IP 段,并尝试使用 iptables 进行封禁:

shell> iptables -A INPUT -s x.y.z.0/24 -j DROP

我原本以为这样就能解决问题,然而结果却让我大失所望——似乎这些措施完全无效。难道这些“小偷”已经找到了绕过封锁的方法?这不太可能!我的直觉告诉我,这可能与 LVS 有关,但遗憾的是我对 LVS 的了解非常有限。我唯一知道的是项目使用的是 FULLNAT 模式,于是我决定从这个角度开始深入调查:

记一次LVS/Nginx环境下的访问控制LVS FULLNAT

FULLNAT 模式的工作原理是,当用户请求通过 LVS 转发到 RS 服务器时,源 IP 会被替换为 LVS 的内网 IP,而目标 IP 则从 LVS 的 VIP 变成 RS 服务器的 IP;当 RS 服务器响应通过 LVS 发送回用户时,源 IP 从 RS 服务器的 IP 变为 LVS 的 VIP,目标 IP 从 LVS 的内网 IP 变为用户的 IP。

备注:如需了解更多关于 LVS 的详细信息,请参考「从一个开发的角度看负载均衡和LVS」一文。

然而,矛盾的是,尽管 RS 服务器看到的是 LVS 的 IP,Nginx 日志中却记录的是客户端的 IP。这是为什么呢?原来 LVS 在 FULLNAT 模式下引入了 TOA 补丁机制,通过 TCP 三次握手阶段的 options 传递用户 IP 和端口信息,从而覆盖 socket 的 IP 和端口数据。

剑鱼论坛系统
剑鱼论坛系统

一款轻论坛系统,由鲶鱼CMS官方开发并发布,剑鱼系统有着轻便、快捷、稳定、易用的特点,系统针对论坛类网站的特点进行了专门的设计和制作,可适应在大数据量下保持高负载访问能力,系统访问速度在普通软硬件环境下处理单次请求可达到0.01秒级别,运行环境的软硬件配置高的情况下可达到0.00X秒。

下载

换句话说,从 iptables 的角度看,RS 服务器上看到的都是 LVS 的 IP,而从 Nginx 的角度看,由于 TOA 的作用,记录的是用户的 IP。这可以通过 tcpdump 命令抓包来验证:

记一次LVS/Nginx环境下的访问控制tcpdump

备注:如图所示,254 开头的字符串中包含了用户的 IP 和端口信息。

因此,可以得出结论:在 RS 服务器上使用 iptables 封禁用户 IP 是无效的,因为我无法操作 LVS 服务器,只能在 RS 服务器上想办法。由于 Nginx 能够获取到用户的 IP,我们可以选择在 Nginx 上解决这个问题。Nginx 提供了 Access、GEO 等多个模块供选择,这里我们选择 GEO 模块:

geo $bad {
    default 0;
    x.y.z.0/24 1;
}

location / {
    if ($bad) {
        return 403;
    }
}

关于 GEO 模块的使用,有许多优秀的参考资料可供查阅,这里就不再赘述。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

230

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

499

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3509

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

3

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

swoole入门物联网开发与实战
swoole入门物联网开发与实战

共15课时 | 1.2万人学习

swoole项目实战(第二季)
swoole项目实战(第二季)

共15课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号