0

0

ss -m 显示 TCP 内存爆炸但进程 RSS 正常的 orphaned socket 清理方法

舞夢輝影

舞夢輝影

发布时间:2026-02-11 20:51:24

|

651人浏览过

|

来源于php中文网

原创

这是典型的 orphaned socket(孤儿套接字)堆积现象:连接已断开、应用层释放 socket 后内核未及时回收,sk_buff 内存仍计入 tcp_memory_allocated 但无对应进程 RSS。

ss -m 显示 tcp 内存爆炸但进程 rss 正常的 orphaned socket 清理方法

ss -m 显示 TCP 内存暴涨但 ps/htop 看不到对应进程 RSS 占用

这是典型的 orphaned socket(孤儿套接字)堆积现象:连接已断开、应用层早已释放 socket,但内核尚未彻底回收,sk_buff 和相关内存仍挂在 tcp_memory_allocated 计数器里。它不归属任何用户进程,所以 pstoppmap 都看不到 RSS 上升。

常见诱因包括:短连接洪峰后服务端未及时调用 close()(尤其 fork 子进程后父进程忘了关 fd)、应用崩溃但 socket 未被 kernel 彻底清理、或设置了 SO_LINGER 且 linger 时间过长。

  • ss -m -i state establishedss -m -i state time-wait 观察单个连接的 rmem_alloc/wmem_alloc,若大量连接显示非零但无对应 PID,基本可确认是 orphaned
  • /proc/net/sockstat 中的 orphan 行会直接暴露数量:TCP: inuse 1234 orphan 890 tw 567 —— 这里的 orphan 890 就是关键指标
  • 不要依赖 netstat,它无法显示 ss -m 的内存字段,且在高连接数下性能差、易丢数据

Linux 内核如何判定并回收 orphaned socket

内核不会无限保留 orphaned socket。是否回收、何时回收,取决于三个硬性阈值和一个软性策略:

  • /proc/sys/net/ipv4/tcp_max_orphans:全局上限。一旦 orphan 数量超此值,内核会强制重置(RST)新建立的连接,**不等超时**
  • /proc/sys/net/ipv4/tcp_fin_timeout:仅影响 FIN_WAIT_2 状态的孤儿连接,对已完全关闭(即进入 TIME_WAIT 或已从连接哈希表移除)的 orphan 无效
  • 真正决定“存活时间”的是 tcp_retries2(默认 15),它控制 FIN 重传次数;但 orphaned socket 已无重传行为,所以这个参数实际不生效
  • 关键机制是内存压力驱动回收:当 tcp_memory_allocated 接近 tcp_mem[2](即 /proc/sys/net/ipv4/tcp_mem 的第三个值),内核会主动扫描并销毁 orphaned socket,哪怕它们还没到“理论超时”

快速验证是否是内存压力触发的延迟回收

如果 ss -m 显示大量 orphaned socket 却迟迟不释放,先看内核是否卡在“等内存压力”这一步:

Colourlab.ai
Colourlab.ai

好莱坞内容创作者依赖的AI色彩分级软件

下载
  • 运行 cat /proc/sys/net/ipv4/tcp_mem,得到三个数字,例如 123456 234567 345678;第三个值 345678 是 high watermark(单位为页)
  • 查当前分配量:cat /proc/net/sockstat | grep -i memory → 找 allocated 后面的数字(单位也是页)
  • allocated 接近甚至超过 tcp_mem[2],说明内核正在节流,orphaned socket 会被优先干掉;反之若远低于,那它们就真可能卡在链表里不动了
  • 临时加压测试:用 echo 1 > /proc/sys/net/ipv4/tcp_low_latency(不推荐生产)或人为制造 socket 分配(如快速建连断连脚本),观察 orphan 数是否下降

线上应急清理与长期规避建议

没有一键清 orphaned socket 的命令 —— 它们本就不属于任何进程,killlsof 都无效。唯一可靠路径是让内核自己回收,或重启网络子系统(风险高,不推荐)。

  • 紧急时可小幅调低 tcp_max_orphans(如从 32768 改为 8192):echo 8192 > /proc/sys/net/ipv4/tcp_max_orphans,内核会立即扫描并踢掉超额部分
  • 长期方案必须从应用侧入手:检查所有 fork() 后的 socket fd 是否被显式 close();禁用 SO_LINGER 或设 linger.l_linger = 0;使用 epoll 时确保 EPOLLIN|EPOLLRDHUP 被监听,及时捕获对端关闭
  • 注意:调大 tcp_mem 只是延缓问题,不能解决根源;而盲目调小 tcp_fin_timeout 对 orphaned socket 几乎没用

最常被忽略的一点:Go 的 http.Server 默认启用 KeepAlive,但若客户端异常断连(比如移动网络切换),连接可能滞留在 ESTABLISHED 状态却不发数据,最终变成 orphaned。这时得靠 ReadTimeout + WriteTimeout 主动断连,而不是等内核收。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

409

2023.07.18

堆和栈区别
堆和栈区别

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

586

2023.08.10

http500解决方法
http500解决方法

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

453

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

434

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

2909

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2437

2024.08.16

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1480

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

712

2023.06.29

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

68

2026.02.11

热门下载

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

精品课程

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

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