0

0

tcp_max_syn_backlog 调到 8192 后仍然大量 SYN_RECV 的隐藏原因

冷炫風刃

冷炫風刃

发布时间:2026-01-25 18:15:12

|

216人浏览过

|

来源于php中文网

原创

真正卡住 SYN_RECV 的是 conntrack 表、accept queue 和端口资源的组合瓶颈,而非仅 tcp_max_syn_backlog;需依次排查 nf_conntrack_max、net.core.somaxconn、ip_local_port_range 等参数及硬件丢包。

tcp_max_syn_backlog 调到 8192 后仍然大量 syn_recv 的隐藏原因

tcp_max_syn_backlog 不是唯一瓶颈

调高 tcp_max_syn_backlog 只是解决了半连接队列(SYN queue)的长度限制,但实际进入该队列前,SYN 包必须先通过 netfilter 的连接跟踪(conntrack)模块、被路由子系统接受、且未被防火墙(如 iptablesnftables)丢弃。如果 conntrack 表已满,内核会直接丢弃新 SYN,根本不会走到 tcp_max_syn_backlog 这一关。

  • net.netfilter.nf_conntrack_max 默认值往往偏低(如 65536),在高并发短连接场景下极易耗尽
  • 可通过 cat /proc/sys/net/nf_conntrack_count 实时查看当前连接跟踪数
  • conntrack 耗尽时,dmesg 中常出现 "nf_conntrack: table full, dropping packet"
  • 调整后需同步增大 net.netfilter.nf_conntrack_buckets(建议为 nf_conntrack_max 的 1/4 ~ 1/2)以避免哈希冲突导致性能下降

SYN\_RECV 大量堆积的真实触发点:accept queue 满 + 应用层处理慢

很多运维误以为 SYN_RECV 多 = 半连接队列满,其实更常见的是:三次握手已完成(连接进入 ESTABLISHED 状态),但应用层没及时调用 accept(),导致全连接队列(accept queue)溢出,内核被迫重传 SYN+ACK 并维持大量处于 SYN_RECV 状态的“伪半连接”——这是 TCP 实现的一个易混淆行为:当 accept queue 满时,Linux 会继续应答 SYN,但不把连接移入 ESTABLISHED,而是卡在 SYN_RECV,直到超时或队列腾出空间。

  • 检查 netstat -s | grep -i "listen overflows",若数值持续增长,说明 accept queue 经常溢出
  • net.core.somaxconn 必须 ≥ 应用 listen() 调用时传入的 backlog 参数,否则会被截断
  • Golang 的 net.Listen("tcp", ":8080") 默认 backlog 是 128;Java NIO 的 ServerSocketChannel#bind 默认可能更低
  • 应用若使用单线程 accept(如简单 while 循环阻塞调用),在高并发下极易成为瓶颈

TIME\_WAIT 泛滥间接压垮 SYN\_RECV 处理能力

大量 TIME_WAIT 连接本身不直接导致 SYN_RECV 增多,但会显著增加内核协议负担:每个 TIME_WAIT 占用一个 socket 结构体、消耗内存、参与哈希表查找,并影响端口复用效率。当 net.ipv4.ip_local_port_range 较窄(如默认 32768–65535),且应用频繁建连又快速关闭,可用源端口很快耗尽,新连接被迫等待端口释放,表现为 SYN 发不出或重传延迟,进而让已有 SYN_RECV 状态连接滞留更久。

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载
  • 确认是否真需要调优:仅当 ss -s | grep -i "time_wait" 显示数万以上且伴随连接建立失败时才需干预
  • 启用 net.ipv4.tcp_tw_reuse = 1(仅对客户端有效)或 net.ipv4.tcp_fin_timeout 缩短回收时间(慎用,可能引发 RST)
  • 更推荐方案:服务端改用连接池、长连接,或由负载均衡器(如 LVS、Envoy)统一管理连接生命周期

别忽略硬件和中间设备的影响

即使内核参数全部调优到位,SYN_RECV 异常仍可能来自链路层:网卡中断合并(RPS/RFS 配置不当)、网卡驱动丢包、物理交换机 ACL 限速、云厂商安全组隐式限流(如 AWS Security Group 每秒新建连接数上限)、甚至 TLS 握手前的 SYN Flood 防御策略自动触发限速。

  • ethtool -S eth0 | grep -i "drop\|error" 查看网卡硬件丢包计数
  • 抓包确认 SYN 是否真正到达服务器:tcpdump -i any 'tcp[tcpflags] & (tcp-syn) != 0 and port 80'
  • 对比 ss -sSYNs to LISTEN sockets ignoredembryonic connections dropped 数值,前者指向底层丢包或过滤,后者才与 tcp_max_syn_backlog 直接相关
真正卡住 SYN_RECV 的,往往是 conntrack 表、accept queue、端口资源这三者的组合瓶颈,而不是单个 sysctl 参数能解决的。调参前,先看 ss -sdmesg,比盲目加数字有用得多。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

845

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

745

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

741

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

420

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16947

2023.08.03

c++ 根号
c++ 根号

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

45

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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