0

0

Linux 服务器被大量 SYN 包淹没但 conntrack 表没满的几种隐藏攻击方式

冷炫風刃

冷炫風刃

发布时间:2026-01-17 22:51:09

|

774人浏览过

|

来源于php中文网

原创

SYN洪水但conntrack未满,说明攻击绕过连接跟踪机制:1.伪造IP+随机端口致SYN队列溢出;2.恶意TCP选项引发协议栈异常;3.双栈/隧道接口未加载对应conntrack模块;4.SYN混杂UDP/ICMP碎片耗尽分片缓存。

linux 服务器被大量 syn 包淹没但 conntrack 表没满的几种隐藏攻击方式

SYN 洪水但 conntrack 未满:攻击绕过了连接跟踪机制

这通常说明攻击流量并未真正进入 ESTABLISHED 状态,也未在 conntrack 表中长期驻留。Linux 的 conntrack 只跟踪已通过三次握手、或明确被内核判定为“需要状态跟踪”的连接(如 RELATED/ESTABLISHED)。而以下几种方式能让 SYN 包持续冲击服务器,却几乎不占用 conntrack 条目:

1. 源端口随机 + 源 IP 伪造(纯 SYN Flood)

攻击者用大量伪造的源 IP 和随机源端口发送 SYN,服务端回复 SYN-ACK 后收不到 ACK(因源 IP 不存在或被丢弃),连接卡在 SYS_RECV 状态。该状态由 tcp_max_syn_backlog 队列管理,不进入 conntrack 表。只要队列溢出,新 SYN 就被丢弃,但 conntrack 表看起来空空如也。

  • 检查命令:netstat -s | grep -i "SYN\|listen\|overflow",关注 times the listen queue of a socket overflowed
  • 关键参数:net.ipv4.tcp_max_syn_backlog(默认常为 128–1024)、net.core.somaxconnnet.ipv4.tcp_syncookies(开启可缓解)

2. TCP Options 恶意组合触发协议异常

某些构造异常的 TCP Options(如超长 SACK 块、重复 Timestamp、非法 MSS)会让内核在 SYN 处理阶段反复解析、分配临时结构体,甚至引发 soft lockup 或内存碎片。这类包可能根本没走到 conntrack 插入逻辑,却持续消耗 CPU 和内存。

  • 现象:softirq CPU 占用高(top -H 查看 ksoftirqd/* 线程)、dmesg 出现 "TCP: too many orphaned sockets""TCP: time wait bucket table overflow"
  • 应对:启用 net.ipv4.tcp_invalid_ratelimit 限制错误包日志频率;用 tcpdump -nn -s 64 'tcp[tcpflags] & (tcp-syn|tcp-ack) == tcp-syn' 抓包分析选项字段

3. 利用 IPv6/IPv4 双栈或隧道接口绕过 conntrack 规则

若服务器启用了 6to4、ISATAP、GRE 或 IPv6,而 conntrack 模块未加载对应协议支持(如 nf_conntrack_ipv6nf_conntrack_proto_gre),这些流量默认不被跟踪。攻击者可定向发 SYN 到隧道接口或 IPv6 地址,完全避开 conntrack 表限制。

京点点
京点点

京东AIGC内容生成平台

下载
  • 验证:运行 lsmod | grep nf_conntrack,确认是否加载了对应协议模块
  • 检查接口:用 ip -br a 查看是否有非主网卡的隧道/虚拟接口;用 conntrack -L | wc -l 对比 IPv4/IPv6 条目数(若 IPv6 条目极少但流量高,值得怀疑)

4. SYN 混合 UDP/ICMP 碎片攻击协同压制

单独发 SYN 效果有限,但配合大量伪造源的 UDP 碎片包(如 DNS 反射放大)或 ICMP 超大载荷包,会快速耗尽内核 sk_buff 缓存和 nf_defrag_ipv4/6 分片重组队列。一旦分片重组失败,SYN 包即使合法也无法完成解析,更不会进入 conntrack 流程——此时 netstat 看不到 backlog 溢出,但连接建立成功率骤降。

  • 线索:cat /proc/net/nf_conntrack | wc -l 很低,但 netstat -s | grep -A5 "fragment" 显示大量 "reassembly failed"
  • 临时缓解:echo 1 > /proc/sys/net/ipv4/ipfrag_high_thresh(谨慎调高,需配合内存监控)

排查建议:别只盯 conntrack 表

真正瓶颈往往在协议栈更上层或更底层:SYN 队列长度软中断处理能力分片缓存socket 内存压力。用 ss -s 查总 socket 数量与内存使用,用 perf top -e 'syscalls:sys_enter_accept*' -p $(pgrep nginx|head -1) 看 accept 是否卡住,比单纯查 conntrack 更有效。

相关专题

更多
nginx 重启
nginx 重启

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

229

2023.07.27

nginx 配置详解
nginx 配置详解

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

498

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的相关内容,可以阅读本专题下面的文章。

3508

2024.08.07

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

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

14

2026.01.13

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

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

19

2026.01.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.3万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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