0

0

ip_local_port_range 用尽后 bind 失败的 ephemeral port 监控与自动扩容脚本

冷漠man

冷漠man

发布时间:2026-01-31 18:23:02

|

846人浏览过

|

来源于php中文网

原创

bind失败主因常是ip_local_port_range耗尽而非端口被占;大量短连接使TIME_WAIT堆积,内核标记整个端口区间暂不可用,触发“Cannot assign requested address”错误。

ip_local_port_range 用尽后 bind 失败的 ephemeral port 监控与自动扩容脚本

为什么 bind 失败不一定是因为端口被占,而是 ip_local_port_range 耗尽

Linux 的 ephemeral port 不是“用一个少一个”地永久占用,而是由 net.ipv4.ip_local_port_range 定义的区间(默认 32768 60999,共约 28K 端口)决定可用上限。当大量短连接(如 HTTP client、gRPC outbound)密集建立又快速关闭时,TIME_WAIT 状态会卡住端口几秒,叠加高并发,bind 就可能直接返回 Cannot assign requested address —— 这不是某个端口被占,而是整个范围已被内核标记为“暂不可用”。ss -s 显示的 tw 数量远超预期,或 /proc/sys/net/ipv4/ip_local_port_range 输出值过窄,就是典型信号。

怎么实时监控当前 ephemeral port 分配压力

不能只看 netstat -an | grep TIME_WAIT | wc -l,它漏掉未进入 TIME_WAIT 但已分配出去的端口。真正有效的指标是内核统计的已分配 ephemeral port 数:

  • cat /proc/net/snmp | awk '/^TcpExt/ && /EmbryonicRsts|SynCookiesFailed/ {print}' —— 看是否因端口不足导致 SYN 丢弃
  • awk '$1 ~ /InUse/ {print $2}' /proc/net/ip_vs_stats —— 不适用;改用:cat /proc/net/sockstat | grep "TCP: inuse" 中的 inuse 值,它反映当前所有已分配(含 ESTABLISHED/TIME_WAIT)的 TCP socket 数
  • 更准的是:awk '/^tcp/ {if($4=="01") c++} END{print c+0}' /proc/net/tcp* 统计所有处于 TIME_WAIT 的 socket(状态码 01),再结合 sysctl net.ipv4.ip_local_port_range 计算占用率

建议每 5 秒采样一次 inusetime_wait,当 inuse / (high-low) > 0.8 且持续 3 次,就触发扩容逻辑。

如何安全地动态扩容 ip_local_port_range

不能直接写死扩大到 1024 65535:低端口(

Sesame AI
Sesame AI

一款开创性的语音AI伴侣,具备先进的自然对话能力和独特个性。

下载
  • 推荐策略:从默认 32768 60999 扩至 16384 65535(共 ~49K),覆盖更多低频长连接场景,同时避开 0–1023 特权端口区
  • 执行命令:sysctl -w net.ipv4.ip_local_port_range="16384 65535",并写入 /etc/sysctl.conf 防重启丢失
  • 注意:该参数热生效,但**仅对新创建的 socket 生效**,已有连接不受影响;扩容后需观察 ss -stotal: 12345 是否缓慢回落,确认内核已开始使用新区间

自动扩容脚本的关键设计点

脚本不是“一发现高就扩”,而是要防抖、防误扩、可逆:

  • 必须加锁(如 flock -n /tmp/ip_local_port_range.lock),避免多实例并发修改
  • 记录上次扩容时间戳和原始值到 /var/run/ip_local_port_range.last,便于故障回滚
  • 检查是否已扩容过:sysctl net.ipv4.ip_local_port_range | grep -q "16384.*65535",避免重复操作
  • 拒绝在容器环境(/proc/1/cgroupdockerkubepods)中执行,因容器网络命名空间隔离,宿主机 sysctl 不生效
  • 示例判断逻辑片段:
    current=$(sysctl -n net.ipv4.ip_local_port_range)
    low=${current%% *}; high=${current##* }
    range=$((high - low))
    inuse=$(grep "TCP: inuse" /proc/net/sockstat | awk '{print $3}')
    if (( $(echo "$inuse / $range > 0.85" | bc -l) )); then
      # 执行扩容...
    fi

最易被忽略的是:扩容后不检查 net.ipv4.tcp_fin_timeoutnet.ipv4.tcp_tw_reuse 是否配合调整 —— 如果只扩 range 却放任 TIME_WAIT 堆积 60 秒,压力只会转移而非缓解。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.09.27

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

783

2023.08.22

堆和栈的区别
堆和栈的区别

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

398

2023.07.18

堆和栈区别
堆和栈区别

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

575

2023.08.10

http500解决方法
http500解决方法

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

434

2023.11.09

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

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

420

2023.11.14

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

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

2413

2024.03.12

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

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

2143

2024.08.16

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

热门下载

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

精品课程

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

共48课时 | 8.2万人学习

Git 教程
Git 教程

共21课时 | 3.2万人学习

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

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