0

0

Linux网络优化实践方案_稳定通信策略解析【教程】

冷漠man

冷漠man

发布时间:2026-01-01 08:07:22

|

146人浏览过

|

来源于php中文网

原创

net.ipv4.tcp_tw_reuse仅对客户端新出站连接有效,需tcp_timestamps=1配合,服务端无效;ss -i的retrans非累计值;somaxconn与应用backlog取最小值;UDP丢包因无socket或缺SO_REUSEPORT。

linux网络优化实践方案_稳定通信策略解析【教程】

为什么 net.ipv4.tcp_tw_reuse 开启后连接仍超时?

因为该参数只对客户端有效,且仅在 TIME_WAIT 状态套接字可被复用于**新 outbound 连接**(即本机主动发起的连接),不适用于服务端接收连接或被动关闭场景。常见误用是把它当成“解决端口耗尽万能开关”,但实际需配合 net.ipv4.tcp_fin_timeout 和连接池策略。

  • 必须确保 net.ipv4.tcp_timestamps = 1 已启用,否则 tcp_tw_reuse 不生效
  • 若应用使用短连接且并发高(如 HTTP client 频繁调用 API),建议同时调小 net.ipv4.tcp_fin_timeout 至 30 秒以内
  • 服务端(如 Nginx、Redis)无法靠此参数缓解 TIME_WAIT 压力,应改用连接复用(keepalive)或反向代理层做连接收敛

如何让 ss -i 显示真实重传与拥塞窗口信息?

ss -i 默认输出中 retrans 字段为 0 并不表示无重传——它只显示当前连接最近一次重传事件的计数,且需内核开启 TCP info 支持。要获取稳定可观测数据,得结合 /proc/net/snmptcpretrans 工具

  • 检查是否启用详细 TCP 统计:cat /proc/net/snmp | grep -A1 Tcp | tail -1,看 RetransSegs 是否持续增长
  • ss -i dst 8.8.8.8 只能观察单条连接瞬时状态;批量诊断请用 tcpretrans -C(来自 perf-tools 包)
  • cwnd 长期卡在 10 MSS 以下,大概率是链路丢包或接收方通告窗口过小,而非本机配置问题

net.core.somaxconn 和应用 listen() 的 backlog 参数谁起作用?

两者共同限制全连接队列长度,最终生效值取二者最小值。很多服务(如 Nginx、Node.js)默认 backlog 设为 511,若系统 net.core.somaxconn 仍为旧版默认值 128,就会 silently 截断连接请求,表现为偶发性 “Connection refused” 或 SYN_RECV 滞留。

STORYD
STORYD

帮你写出让领导满意的精美文稿

下载
  • 先确认当前值:sysctl net.core.somaxconn,生产环境建议设为 65535
  • Nginx 需显式配置 listen 80 backlog=65535;;Node.js 的 server.listen(port, cb) 第二个参数可传 backlog 数值
  • 修改后必须重启对应服务进程,仅 reload 不生效(因 listen() 在进程启动时调用)

UDP 应用丢包但 netstat -su 显示 no socket 错误?

这说明数据包到达了 IP 层,但找不到匹配的 UDP socket——常见于端口未监听、进程已崩溃、或 bind() 时未设 SO_REUSEPORT 导致多 worker 场景下部分包被内核丢弃。

  • ss -uln | grep :端口号 确认端口确实在监听,注意 ss 输出中的 State 列应为 UNCONN
  • 若使用多进程/线程模型(如 Gunicorn + UDP handler),必须在每个进程 bind 前设置 SO_REUSEPORT,否则仅第一个进程能收包
  • netstat -su 中的 no socket 计数不会自动清零,需对比前后差值判断是否持续发生
#!/bin/bash
# 快速检查关键网络参数是否就绪
for p in net.core.somaxconn net.ipv4.tcp_tw_reuse net.ipv4.tcp_timestamps; do
    v=$(sysctl -n $p 2>/dev/null)
    echo "$p = $v"
done
echo "TCP retransmit segments: $(awk '/Tcp:/ {print $13}' /proc/net/snmp 2>/dev/null)"

真正影响稳定的不是单个 sysctl 调优,而是连接生命周期各环节的协同:TIME_WAIT 处理方式是否匹配你的客户端/服务端角色,全连接队列是否被低估,UDP 多实例是否正确启用 SO_REUSEPORT。这些点一旦错位,再精细的拥塞控制参数也压不住丢包。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

227

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

490

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

496

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

223

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

329

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3505

2024.08.07

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

471

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

508

2023.06.20

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

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

7

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号