0

0

Linux网络连接异常排查教程_TIMEWAIT与CLOSEWAIT

舞夢輝影

舞夢輝影

发布时间:2026-01-01 13:24:08

|

641人浏览过

|

来源于php中文网

原创

TIME_WAIT和CLOSE_WAIT非错误但数量异常预示连接释放问题;TIME_WAIT确保ACK送达和防旧包干扰,端口耗尽主因是短连接风暴或NAT会话满;CLOSE_WAIT过多表明应用未调用close()致资源泄漏,需定位进程并检查代码/配置。

linux网络连接异常排查教程_timewait与closewait

Linux网络连接异常中,TIME_WAITCLOSE_WAIT 是两个高频且易被误解的状态。它们本身不是错误,但数量异常激增往往预示着连接释放不及时、服务端响应延迟、客户端未正确关闭连接等问题。排查关键在于理解状态成因、定位源头进程、评估是否真实影响服务,而非简单“调大内核参数”或“暴力回收”。

理解 TIME_WAIT 的作用与风险点

TIME_WAIT 出现在主动发起关闭(发送 FIN)的一方,持续 2×MSL(通常为 60 秒)。它的核心作用是:确保被动关闭方能收到最后的 ACK;防止旧连接的延迟报文干扰新连接(相同四元组重用时)。常见误判是“TIME_WAIT 占用端口导致无法新建连接”——实际上 Linux 默认允许端口复用(net.ipv4.ip_local_port_range + TIME_WAIT 复用机制),真正瓶颈多是端口耗尽(如短连接风暴)或 NAT 设备会话表满。

  • 检查当前数量:ss -s | grep "timewait"netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
  • 确认是否真端口不足:ss -ant | awk '{print $4}' | cut -d':' -f2 | sort | uniq -c | sort -nr | head -10 查看高频本地端口分布
  • 慎用 net.ipv4.tcp_tw_reuse:仅对客户端有效(需 timestamps 开启),服务端启用可能引发 RST;net.ipv4.tcp_tw_recycle 已在 4.12+ 内核移除,切勿配置

定位 CLOSE_WAIT 过多的根本原因

CLOSE_WAIT 出现在被动关闭方(通常是服务端),表示对方已发 FIN,本方收到并回复 ACK,但应用层尚未调用 close()。这意味着**程序没有正确关闭 socket**——这是典型的资源泄漏信号。数量持续增长,往往伴随句柄耗尽、新连接拒绝(too many open files)或请求堆积。

XPaper Ai
XPaper Ai

AI撰写论文、开题报告生成、AI论文生成器尽在XPaper Ai论文写作辅助指导平台

下载
  • 快速定位进程:ss -tanp | grep CLOSE-WAIT(需 root 权限查看进程名)
  • 查具体连接和 PID:lsof -iTCP -sTCP:CLOSE_WAIT -n -P,重点关注 PID 和文件描述符数
  • 结合进程状态:ps -p -o pid,ppid,comm,etime,cmd 看是否僵死、CPU/IO 是否异常
  • 典型场景:Java 应用未关闭 InputStream/OutputStream;Nginx 后端超时设置过长,上游迟迟不关连接;Go HTTP server 未设 ReadTimeout/WriteTimeout 导致 goroutine 挂起

实用排查流程:从现象到修复

不建议一上来就改 sysctl。优先走“现象→连接分析→进程追踪→代码/配置验证”路径:

  • 监控基线:用 ss -s 定期采样,对比正常时段数值(如 TIME_WAIT 稳定在 5k~10k,突增至 50k+ 需警觉)
  • 抓包辅助判断:tcpdump -i any port -w closewait.pcap,过滤出 FIN/ACK 交互,确认哪端先断、是否有重传或超时
  • 检查服务日志:搜索 “broken pipe”、“connection reset”、“I/O timeout”,常暴露下游异常断连
  • 验证连接释放逻辑:对自研服务,检查 close() 是否在 finally 块或 defer 中执行;对 Nginx/Apache,确认 proxy_timeout、keepalive_timeout 设置合理(如 upstream 超时应小于 client_header_timeout)

调整建议:只在明确必要时进行

内核参数是兜底手段,非根治方案。以下调整需严格测试:

  • 减小 TIME_WAIT 持续时间:不推荐修改 net.ipv4.tcp_fin_timeout(仅影响 FIN_WAIT_2),TIME_WAIT 固定为 2MSL,无法缩短
  • 扩大可用端口范围:echo 'net.ipv4.ip_local_port_range = 1024 65535' >> /etc/sysctl.conf,适用于高并发短连接客户端
  • 优化连接复用:net.ipv4.tcp_tw_reuse = 1(客户端场景)、net.ipv4.tcp_timestamps = 1(必须开启)
  • 限制最大 TIME_WAIT 数量(应急):net.ipv4.tcp_max_tw_buckets = 2000000,超出后内核强制回收,但可能丢包,仅限临时缓解

相关专题

更多
java
java

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

825

2023.06.15

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

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

724

2023.07.05

java自学难吗
java自学难吗

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

728

2023.07.31

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

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

395

2023.08.01

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

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

398

2023.08.02

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

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

445

2023.08.02

java有什么用
java有什么用

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

429

2023.08.02

java在线网站
java在线网站

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

16881

2023.08.03

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

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

精品课程

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

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

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

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