0

0

Linux TCP/IP 参数调优方法

舞姬之光

舞姬之光

发布时间:2026-02-22 19:31:03

|

876人浏览过

|

来源于php中文网

原创

tcp_slow_start_after_idle 默认开启导致空闲连接恢复时退回到慢启动,吞吐骤降;应设为0并持久化。

linux tcp/ip 参数调优方法

tcp_slow_start_after_idle 导致连接吞吐突然下降

Linux 默认开启 tcp_slow_start_after_idle,空闲连接重传时会退回到慢启动状态——哪怕之前已跑满带宽。这不是 bug,是 RFC 规定行为,但对长连接、RPC 调用、数据库连接池等场景很不友好。

实操建议:

  • 确认当前值:sysctl net.ipv4.tcp_slow_start_after_idle(默认为 1)
  • 关闭它:sysctl -w net.ipv4.tcp_slow_start_after_idle=0,并写入 /etc/sysctl.conf 持久化
  • 注意:仅影响空闲后恢复的连接,不影响新建连接;内核 4.1+ 支持该参数,老版本需升级或绕过

net.core.somaxconn 和应用 listen() 的 backlog 不匹配

应用调用 listen(fd, backlog) 时传的 backlog 值,会被内核截断为 net.core.somaxconn 的最小值。若应用设了 1024,但系统值是 128,实际队列长度就是 128——SYN 队列溢出直接丢包,表现为偶发连接超时或拒绝。

实操建议:

  • 查当前限制:sysctl net.core.somaxconn,同时用 ss -lnt 看实际监听队列长度(Recv-Q 列)
  • 调高它:sysctl -w net.core.somaxconn=4096;Go/Java 等语言默认 backlog 常为 50~128,务必同步检查应用层配置
  • 注意:Docker 容器内需在 host 或 cgroup 层设置,容器启动时 --sysctl 可透传,但部分托管平台(如 EKS)可能拦截

net.ipv4.tcp_tw_reuse 在 NAT 环境下引发 TIME_WAIT 冲突

net.ipv4.tcp_tw_reuse 允许复用处于 TIME_WAIT 状态的 socket,前提是时间戳严格递增。但在大量客户端共用一个出口 IP(如 Kubernetes Node、云 NAT 网关)时,不同连接的时间戳可能碰撞,导致 RST 或连接失败。

大师兄智慧家政
大师兄智慧家政

58到家打造的AI智能营销工具

下载

实操建议:

  • 只在明确可控的客户端侧启用(如单机压测脚本),服务端禁用更安全
  • 替代方案优先调小 net.ipv4.tcp_fin_timeout(默认 60s)至 30s,或增大 net.ipv4.ip_local_port_range 扩展可用端口
  • 验证是否真有瓶颈:用 ss -tan state time-wait | wc -l 统计数量,>3w 才值得动参数,别一上来就改

net.ipv4.tcp_congestion_control 切换后未生效

改完 net.ipv4.tcp_congestion_control 后,新连接仍走旧算法,常见原因是:没有重启已有连接,或未加载对应内核模块(如 bbrlsmod | grep bbr 确认)。

实操建议:

  • 查看当前算法:sysctl net.ipv4.tcp_congestion_control
  • 加载模块(以 bbr 为例):modprobe tcp_bbr,再执行 sysctl -w net.ipv4.tcp_congestion_control=bbr
  • 必须重启测试连接(比如 curl 新请求、telnet 新建 TCP 流),已建立连接不受影响;容器环境注意 init 进程是否继承了父级 TCP 设置

调参不是开箱即用的魔法开关,每个值背后都绑着协议逻辑、硬件延迟、网络拓扑和应用行为。改之前先抓包看三次握手、RTT 分布、重传率,比盲目调 net.ipv4.tcp_rmem 有用得多。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

182

2023.10.30

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

265

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

512

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

411

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

447

2024.04.08

Docker容器化部署与DevOps实践
Docker容器化部署与DevOps实践

本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。

20

2026.02.11

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

463

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.5万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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