0

0

Linux 高并发连接优化策略

舞夢輝影

舞夢輝影

发布时间:2026-02-23 17:43:03

|

919人浏览过

|

来源于php中文网

原创

内核实际生效的backlog是min(somaxconn, listen()传入值),应用层若设小则调大somaxconn无效;tcp_tw_reuse仅对客户端新连接有效且依赖tcp_timestamps;systemd服务需在unit文件配limitnofile;et模式易丢事件因未读完缓冲区数据。

linux 高并发连接优化策略

为什么 net.core.somaxconn 调小了还是被拒绝连接?

因为内核实际生效的 backlog 长度,是 min(somaxconn, listen(sockfd, backlog))。应用层调用 listen() 时传的第二个参数(比如 Node.js 的 server.listen(port, cb) 默认是 511),若小于 net.core.somaxconn,那再怎么调大内核参数也没用。

  • 检查应用代码里是否显式设置了 backlog,如 Python 的 socket.listen(1024)、Go 的 net.Listen("tcp", ":8080") 默认由运行时决定,但某些框架会硬编码低值
  • ss -lnt 查看当前监听 socket 的 Recv-Q 值,持续接近或等于你设的 backlog,说明队列已在溢出边缘
  • 临时验证:启动服务前先 echo 65535 > /proc/sys/net/core/somaxconn,再确保应用调用 listen() 时传入 ≥65535 的值(部分语言 runtime 不支持超大值,需查文档)

net.ipv4.tcp_tw_reuse 开启后反而丢连接?

它只对「客户端主动发起的新连接」有效,且要求 TIME_WAIT socket 对应的四元组(源IP+源端口+目标IP+目标端口)不冲突。服务端大量短连接 + NAT 环境下,复用失败率高,还可能触发对端 RST。

  • 仅在明确是客户端连接池不足(如负载机发请求)时开启;服务端高并发 HTTP API 场景下,优先调大 net.ipv4.ip_local_port_range 和降低 net.ipv4.tcp_fin_timeout
  • tcp_tw_reuse 依赖 tcp_timestamps=1,而某些老旧设备或中间件(如某些防火墙)会丢弃带 timestamp 选项的包,导致握手失败
  • 观察 netstat -s | grep -i "times" pruned from time-wait 是否激增——那是内核强制回收,说明配置没起作用或压力远超预期

文件描述符不够用,ulimit -n 改了却无效?

systemd 服务默认无视 shell 的 ulimit 设置,必须在 service 文件里显式声明 LimitNOFILE,否则进程启动时仍沿用 systemd 的默认限制(通常是 1024)。

Northstar盈富量化交易软件
Northstar盈富量化交易软件

Northstar盈富量化交易软件是一个基于B/S架构的一站式量化交易平台,能进行历史回放、策略研发、模拟交易、实盘交易。 已对接国内期货CTP交易系统,并陆续补充国内股票XTP渠道、老虎证券、币安等多种渠道。这是一个面向程序员的开源高频量化交易软件,用于期货、股票、外汇、炒币等多种交易场景,实现自动交易。暂时只对接了国内期货交易所,理论上可以对接任意交易所。 功能特性:1、一站式平台,可适配对接

下载
  • 查当前进程限制:cat /proc/<pid>/limits | grep "Max open files"</pid>,确认是不是 systemd 拉起的
  • 修改 /etc/systemd/system/<service>.service</service>,加入 LimitNOFILE=65536,然后 systemctl daemon-reload && systemctl restart <service></service>
  • 注意:ulimit -n 只影响当前 shell 及其子进程,无法穿透到由 init 系统管理的守护进程

epoll 边缘场景下 EPOLLETEPOLLONESHOT 更容易丢事件?

ET 模式要求应用必须一次性读完 socket 缓冲区所有数据(直到 recv() 返回 EAGAIN),否则后续可读事件不会再次触发。而 EPOLLONESHOT 是事件触发一次后自动禁用,需手动 epoll_ctl(... EPOLL_CTL_MOD ...) 重新启用,逻辑更可控。

  • HTTP/2 或 TLS 分块传输场景中,单次 recv() 可能只读到半个帧,ET 下若没继续读,连接就“卡住”了
  • EPOLLONESHOT 配合线程池更安全:工作线程处理完一个事件后,再通知 epoll 重新关注该 fd,避免状态竞争
  • glibc 的 readv() 在部分内核版本中与 ET 模式存在边界 bug(如读到 EOF 后未清空缓冲区),建议用 recv(fd, buf, MSG_DONTWAIT) 替代

高并发不是堆参数就能解决的事——每个 sysctl 项背后都对应着内核路径上的具体判断逻辑,改之前得先知道它在哪一环起作用。线上调参最危险的不是设错值,而是没配好配套机制(比如开了 tcp_tw_reuse 却没关 tcp_timestamps,或者调大 somaxconn 却忘了改应用层 backlog)。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

181

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

224

2025.12.18

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

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

422

2023.07.18

堆和栈区别
堆和栈区别

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

595

2023.08.10

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

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

715

2023.08.10

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

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

524

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

454

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

618

2023.08.03

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

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

1127

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.6万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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