0

0

Linux 出现 "nf_conntrack: table full, dropping packet" 如何快速释放并永久调优

冰川箭仙

冰川箭仙

发布时间:2026-01-23 19:48:55

|

466人浏览过

|

来源于php中文网

原创

nf_conntrack: table full 是因连接跟踪表满导致丢包,主因是 nf_conntrack_max 过小或连接回收慢;可临时用 conntrack -F 清空,长期需调大上限、缩短超时、启用 GC 并优化容器与内核兼容性。

linux 出现 \

为什么会出现 nf_conntrack: table full, dropping packet

这是内核 netfilter 的连接跟踪表(conntrack table)被填满导致的丢包,常见于高并发短连接场景(如 HTTP 轮询、NAT 网关、Kubernetes Service 流量),或连接未及时回收(TIME_WAIT 过长、客户端不主动关闭等)。本质不是“内存不够”,而是 nf_conntrack_max 设定值太小,或连接生命周期过长导致条目堆积。

如何快速清空 conntrack 表并验证是否生效

紧急情况下先缓解丢包,再调参:

  • 执行 sudo conntrack -F 清空当前所有连接跟踪条目(注意:会中断所有已建立的 NAT/iptables 相关连接,生产环境慎用)
  • 查看实时使用量:conntrack -C(返回数字,如 65432);对比上限:cat /proc/sys/net/netfilter/nf_conntrack_max
  • 观察是否还在丢包:dmesg -T | grep "nf_conntrack: table full",清空后短期内不应再出现
  • 若需只删特定协议/状态(更安全),例如删掉所有 INVALID 状态:sudo conntrack -D --state INVALID

永久调优:增大上限 + 缩短超时 + 防止泛洪

仅改 nf_conntrack_max 不够,必须配合超时参数和连接清理策略,否则新表很快又满:

知料万语
知料万语

知料万语—AI论文写作,AI论文助手

下载
  • 增大最大连接数:写入 /etc/sysctl.conf,例如 net.netfilter.nf_conntrack_max = 131072(建议设为内存 MB 数 × 16,但不超过 655360)
  • 缩短非活跃连接存活时间:net.netfilter.nf_conntrack_tcp_timeout_established = 43200(默认 432000 秒=5 天,可缩到 12 小时)
  • 对短连接更激进些:降低 FIN_WAIT 和 TIME_WAIT 超时,例如 net.netfilter.nf_conntrack_tcp_timeout_fin_wait = 30net.netfilter.nf_conntrack_tcp_timeout_time_wait = 30
  • 启用自动垃圾回收(关键):net.netfilter.nf_conntrack_gc_interval = 30(每 30 秒触发一次扫描清理)
  • 应用配置:sudo sysctl -p,确认生效:sysctl net.netfilter.nf_conntrack_max

容易被忽略的隐患点

很多运维只调大 nf_conntrack_max,却没意识到:

  • 容器环境(如 Docker、Kubernetes)默认共享宿主机 conntrack 表,一个 Pod 的大量连接就能打爆整个节点 —— 建议在 kube-proxy 中启用 --conntrack-max-per-core 或直接切换到 IPVS 模式
  • nf_conntrack_buckets(哈希桶数量)默认是 nf_conntrack_max / 4,若该值过小会导致哈希冲突升高、查找变慢,可手动设为质数,如 net.netfilter.nf_conntrack_buckets = 65536
  • 某些云厂商(如 AWS ENA、Azure Accelerated Networking)驱动不兼容旧内核的 conntrack 回收逻辑,升级内核或打补丁比调参更治本

相关专题

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

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

394

2023.07.18

堆和栈区别
堆和栈区别

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

574

2023.08.10

k8s和docker区别
k8s和docker区别

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

257

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

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

27

2025.12.22

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

387

2023.11.09

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

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

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