0

0

conntrack 表满导致新连接失败但 netstat/ss 看不出异常的排查顺序

舞夢輝影

舞夢輝影

发布时间:2026-01-23 20:04:02

|

469人浏览过

|

来源于php中文网

原创

netstat 和 ss 不显示异常是因为它们只查看 socket 层连接状态,而 conntrack 表满时新连接在进入协议栈前就被 nf_conntrack 拒绝,根本未到达 socket 层。

conntrack 表满导致新连接失败但 netstat/ss 看不出异常的排查顺序

conntrack 表满时为什么 netstatss 都不显示异常

因为 netstatss 只查 socket 层的连接状态(如 ESTABLISHED、TIME_WAIT),而 conntrack 是 netfilter 的连接跟踪表,用于 NAT、防火墙规则匹配等。新连接在进入协议前就被 nf_conntrack 拒绝了,根本到不了 socket 层,所以这两个工具完全看不到任何“新连接尝试”的痕迹。

快速确认 conntrack 表是否已满

直接看内核统计和当前使用量,比翻日志更快:

  • 运行 cat /proc/sys/net/netfilter/nf_conntrack_count 查当前条目数
  • 运行 cat /proc/sys/net/netfilter/nf_conntrack_max 查上限值
  • 如果前者接近或等于后者(比如 >90%),基本就是瓶颈所在
  • 补充验证:dmesg -T | tail -20 | grep -i "nf_conntrack: table full",有这条日志就实锤了

常见导致 conntrack 泛滥的场景和对应检查点

不是所有连接都会进 conntrack 表,但以下几类特别容易堆积:

抖云猫AI论文助手
抖云猫AI论文助手

一款AI论文写作工具,最快 2 分钟,生成 3.5 万字论文。论文可插入表格、代码、公式、图表,依托自研学术抖云猫大模型,生成论文具备严谨的学术专业性。

下载
  • 大量短连接 + 未启用 nf_conntrack_tcp_be_liberal=1:TCP FIN/RST 乱序时会卡住连接状态,建议开启
  • UDP 流量(尤其是 DNS、NTP):默认超时长达 30 秒,且无握手确认,极易堆积;可通过 sysctl net.netfilter.nf_conntrack_udp_timeout_stream_timeout 分别调低
  • 容器环境(Docker/Podman):每个容器网络命名空间都独立维护 conntrack 表,宿主机上看到的是总和,但实际可能某个 namespace 已满;用 nsenter -n -t $PID -- cat /proc/sys/net/netfilter/nf_conntrack_count 检查具体容器
  • iptables 规则中用了 -m state-m conntrack:即使没做 NAT,只要加载了 nf_conntrack 模块并触发匹配,就会建连接记录

临时缓解与长期调优的关键参数

别只加 nf_conntrack_max,要结合业务特征调整超时和回收逻辑:

  • 临时扩容(重启后失效):sysctl -w net.netfilter.nf_conntrack_max=131072
  • 缩短 TCP 非活跃连接超时:sysctl -w net.netfilter.nf_conntrack_tcp_timeout_established=43200(默认 43200 秒 = 12 小时,对多数服务太长)
  • 加快 TIME_WAIT 回收:sysctl -w net.netfilter.nf_conntrack_tcp_timeout_time_wait=30(默认 120 秒)
  • 启用自动垃圾回收(尤其高并发突增场景):sysctl -w net.netfilter.nf_conntrack_gc_thresh_high=110000,同时设 _low_max 形成水位区间
  • 注意:修改后需运行 sysctl -p 持久化,且某些参数(如 nf_conntrack_max)在模块加载后不可动态增大,必须先 rmmod nf_conntrack 再重设再 modprobe

真正麻烦的不是调参本身,而是不同协议、不同 namespace、不同内核版本对同一参数的响应差异——比如 5.10+ 内核里 nf_conntrack_tcp_be_liberal 默认已开,但 4.19 可能还关着,得挨个核对。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

252

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

495

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

400

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

438

2024.04.08

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

Docker 17 中文开发手册
Docker 17 中文开发手册

共0课时 | 0人学习

极客学院Docker视频教程
极客学院Docker视频教程

共33课时 | 17.9万人学习

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

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