• 千万别忽视!TIME_WAIT 堆积背后的秘密和应对技巧

千万别忽视!TIME_WAIT 堆积背后的秘密和应对技巧

2025-08-16 12:53:01 栏目:宝塔面板 1 阅读

平时运维过程中,你有没有遇到过这种情况:服务器明明没多少请求,但 netstat -an | grep tcp | grep TIME_WAIT 一看,成千上万条 TIME_WAIT 堆积,看着被攻击了一样。

别慌,这不是 Bug,这就是 TCP 的自我保护机制。今天,我帮你彻底弄懂 TIME_WAIT,顺便教你怎么解决它。

1. TIME_WAIT 是什么?

TCP 连接关闭有个“四次挥手”的过程:

  • 客户端发 FIN:我要关闭连接
  • 服务器回 ACK:收到
  • 服务器发 FIN:我也要关闭
  • 客户端回 ACK

主动关闭的一方就会进入 TIME_WAIT,等待 2×MSL(最大报文生存时间),Linux 默认大约 60 秒。

为什么要等?保证最后的 ACK 能被对方收到,避免网络延迟导致数据丢失。

简单来说,TIME_WAIT 就是 TCP 的“安全休眠模式”。

2. 为什么会产生大量 TIME_WAIT?

可能有以下几个原因:

  • 短连接频繁建立:HTTP、Redis、MySQL 的短连接模式,每次请求都是一次开关机,TIME_WAIT 自然堆积。
  • 服务器主动关闭:TIME_WAIT 只出现在主动关闭连接的一方,如果服务端经常主动断开,而客户端被动接受,就会堆很多。
  • 高并发环境:短时间内大量连接关闭,TIME_WAIT 就像小人潮,堆积在系统里。

3. TIME_WAIT 有啥影响?

如果TIME_WAIT堆积过多,会出现下面的问题:

  • 端口耗尽:每个 TIME_WAIT 占用一个端口,如果端口被短时间内重复使用,可能会遇到“端口不够用”的尴尬。
  • 占用内存:每个 TIME_WAIT 会占用少量内存,但 Linux 可以处理大量 TIME_WAIT,一般不会直接 OOM。

换句话说,大量 TIME_WAIT 很正常,不必慌,除非端口用完。

4. 解决方案

(1) TCP 端口重用

允许系统复用 TIME_WAIT 端口,避免端口耗尽。

sysctl -w net.ipv4.tcp_tw_reuse=1

注意:只对客户端主动发起连接有效。

(2) 缩短 TIME_WAIT 时间

减少 TIME_WAIT 保持时间,加快回收。

sysctl -w net.ipv4.tcp_fin_timeout=30

默认约 60 秒,时间太短可能增加重传风险。

(3) 使用长连接 / 连接池

  • HTTP:开启 Keep-Alive,减少重复连接
  • 数据库:使用连接池复用连接

以Nginx为例:

keepalive_timeout 65;
keepalive_requests 100;

(4) 负载均衡

使用 Nginx、LVS、HAProxy,把高并发连接分散到多台服务器,减少单台压力。

核心思路:减少新连接产生 + 缩短或复用 TIME_WAIT + 分散压力

TIME_WAIT 是 TCP 的“安全休眠”,高并发环境堆积很正常。掌握以上方法,就能让 Linux 服务器更稳、更快、更抗压。

本文地址:https://www.yitenyun.com/352.html

搜索文章

Tags

数据库 API FastAPI Calcite 电商系统 MySQL Web 应用 异步数据库 数据同步 ACK 双主架构 循环复制 Deepseek 宝塔面板 Linux宝塔 Docker 生命周期 JumpServer JumpServer安装 堡垒机安装 Linux安装JumpServer 序列 核心机制 esxi esxi6 root密码不对 无法登录 web无法登录 SSL 堡垒机 跳板机 HTTPS Windows Windows server net3.5 .NET 安装出错 宝塔面板打不开 宝塔面板无法访问 查看硬件 Linux查看硬件 Linux查看CPU Linux查看内存 连接控制 机制 HTTPS加密 Windows宝塔 Mysql重置密码 无法访问宝塔面板 HexHub 运维 Oracle 处理机制 Serverless 无服务器 语言 Spring Redis 异步化 ES 协同 技术 group by 索引 InnoDB 数据库锁 监控 开源 PostgreSQL 存储引擎 分页查询 高可用 SQL 动态查询 响应模型 缓存方案 缓存架构 缓存穿透 R edis 线程 数据 主库 自定义序列化 服务器 管理口 scp Linux的scp怎么用 scp上传 scp下载 scp命令 日志文件 MIXED 3 查询 SVM Embedding 存储 OB 单机版 Linux 安全 工具 电商 系统 SQLark SQLite-Web SQLite 数据库管理工具 架构 Rsync Postgres OTel Iceberg RocketMQ 长轮询 配置 Recursive 云原生 流量 共享锁 • 索引 • 数据库 防火墙 黑客 修改DNS Centos7如何修改DNS 向量数据库 大模型 聚簇 非聚簇 sftp 服务器 参数 PG DBA 缓存 业务 AI 助手 Ftp ​Redis 机器学习 推荐模型 场景 GreatSQL 连接数 优化 万能公式 Netstat Linux 服务器 端口 数据备份 MySQL 9.3 openHalo 数据分类 加密 同城 双活 信息化 智能运维 RDB AOF INSERT COMPACT 窗口 函数 人工智能 推荐系统 核心架构 订阅机制 事务 Java 开发 MVCC 磁盘架构 线上 库存 预扣 redo log 重做日志 网络架构 网络配置 Doris SeaTunnel prometheus Alert Redisson 锁芯 向量库 Milvus mini-redis INCR指令 Undo Log 高效统计 今天这篇文章就跟大家 Python 引擎 性能 网络故障 B+Tree ID 字段 模型 IT运维 Canal Web PostGIS Redis 8.0 不宕机 数据脱敏 加密算法 R2DBC Hash 字段 分布式 集中式 崖山 新版本 自动重启 Pottery ZODB 微软 SQL Server AI功能 容器化 虚拟服务器 虚拟机 内存 OAuth2 Token JOIN Entity DBMS 管理系统 MongoDB 容器 数据类型 数据结构 读写 sqlmock 启动故障 悲观锁 乐观锁 分库 分表 LRU SpringAI StarRocks 数据仓库 数据集成工具 分页 单点故障 QPS 高并发 传统数据库 向量化 数据页 工具链 Testcloud 云端自动化 Redka 排行榜 排序 发件箱模式 事务隔离 部署 聚簇索引 非聚簇索引 分页方案 排版 filelock 大表 业务场景 意向锁 记录锁 速度 服务器中毒 Web 接口 1 SSH 池化技术 连接池 Caffeine CP 仪表盘 分布式架构 分布式锁​ dbt 数据转换工具 日志 原子性 EasyExcel MySQL8 AIOPS MCP 开放协议 优化器 网络 InfluxDB Order IT 双引擎 RAG HelixDB 频繁 Codis Go 数据库迁移 字典 单线程 Ansible 对象 Crash 代码 LLM 事务同步 订单 线程安全 Pump List 类型 UUIDv7 主键 服务器性能 TIME_WAIT 负载均衡 锁机制 MGR 分布式集群 并发控制 恢复机制 ReadView 国产数据库 Next-Key 国产 用户 RR 互联网 算法 数据字典 兼容性 GitHub Git 语句 播客 慢SQL优化 拦截器 动态代理 矢量存储 数据库类型 AI代理 千万级 失效 行业 趋势 多线程 Weaviate 分布式锁 Zookeeper 解锁 调优 闪回 产业链 快照读 当前读 视图 关系数据库 编程 主从复制 代理 count(*) count(主键) 行数 UUID ID 神经系统 表空间 Valkey Valkey8.0 查询规划 恢复数据 CAS 技巧