0

0

Linux连接数过高处理_系统参数优化说明【技巧】

舞夢輝影

舞夢輝影

发布时间:2025-12-31 11:13:02

|

912人浏览过

|

来源于php中文网

原创

TIME_WAIT堆积等问题是内核参数未适配业务的信号,需用ss、netstat、cat命令定位瓶颈,再针对性调优文件描述符、TCP队列、TIME_WAIT和缓冲区参数,避免盲目扩容或误用废弃参数。

linux连接数过高处理_系统参数优化说明【技巧】

TIME_WAIT 堆积、新连接超时、accept() 队列溢出、Too many open files 错误——这些不是“流量大了就该扩容”的借口,而是内核参数没对齐业务场景的明确信号。Linux 默认配置面向通用桌面/轻量服务,不调参直接跑百万连接,等于让 8 核 CPU 背着 32GB 内存跑马拉松还穿拖鞋

查清瓶颈在哪,别一上来就改 /etc/sysctl.conf

盲目调大所有参数反而可能引发内存耗尽或连接紊乱。先用三行命令定位真实瓶颈:

  • ss -s:看全局 socket 统计,重点关注 tcp 行的 inuseorphantw(TIME_WAIT 数)
  • netstat -s | grep -i "listen.*drops\|embryonic":若输出非空,说明 SYN 队列已满,tcp_max_syn_backlogsomaxconn 不足
  • cat /proc/sys/net/ipv4/ip_local_port_range:若范围窄(如 32768 60999),短连接密集时端口几秒就耗尽

特别注意:ss -ntp state syn-recv 能实时抓到卡在 SYN_RECV 的半连接——这是 SYN Flood 或队列过小的铁证,不是应用层问题。

文件描述符:进程级和系统级必须双开

每个 TCP 连接占用 1 个文件描述符(fd),ulimit -n 限制单进程上限,fs.file-max 限制全系统上限。二者缺一不可,且 systemd 服务还额外受 DefaultLimitNOFILE 约束。

  • 临时生效(仅当前 shell 及子进程):
    ulimit -n 1048576
  • 永久生效(所有用户):
    echo "* soft nofile 1048576" >> /etc/security/limits.conf
    echo "* hard nofile 1048576" >> /etc/security/limits.conf
    (注意:需重启用户 session 或重连 SSH)
  • 修复 systemd 服务被截断的问题:
    echo "DefaultLimitNOFILE=1048576" >> /etc/systemd/system.conf
    systemctl daemon-reload
    (否则即使 limits.conf 设了,systemctl start nginx 启的服务仍卡在 65536)

⚠️ 坑点:改完 limits.conf 不重连终端,ulimit -n 仍显示旧值;fs.file-max 过大会挤占内核内存,建议设为 内存(GB) × 100000(16GB 内存 → 1600000)。

杰易OA办公自动化系统6.0
杰易OA办公自动化系统6.0

基于Intranet/Internet 的Web下的办公自动化系统,采用了当今最先进的PHP技术,是综合大量用户的需求,经过充分的用户论证的基础上开发出来的,独特的即时信息、短信、电子邮件系统、完善的工作流、数据库安全备份等功能使得信息在企业内部传递效率极大提高,信息传递过程中耗费降到最低。办公人员得以从繁杂的日常办公事务处理中解放出来,参与更多的富于思考性和创造性的工作。系统力求突出体系结构简明

下载

TCP 连接队列与 TIME_WAIT 控制:别碰 tcp_tw_recycle

tcp_tw_recycle 在 4.12+ 内核已被彻底移除,且 NAT 环境下必然丢包——它不是优化项,是历史包袱。真正可用的是:

  • net.ipv4.tcp_tw_reuse = 1:允许复用 TIME_WAIT socket 发起新连接(仅客户端有效,如代理、HTTP 调用方)
  • net.ipv4.tcp_fin_timeout = 30:把默认 60s 缩短,加速 FIN_WAIT_2 状态释放(服务端适用)
  • net.core.somaxconn = 65535net.ipv4.tcp_max_syn_backlog = 65535:防止 accept() 队列和 SYN 队列溢出(必须与应用层 listen(fd, backlog) 参数匹配)
  • net.ipv4.ip_local_port_range = 1024 65535:扩大客户端端口池,避免短连接端口枯竭

⚠️ 坑点:tcp_tw_reuse 依赖 tcp_timestamps = 1(默认开启),但若你关了时间戳(tcp_timestamps = 0),它就完全失效;somaxconn 修改后,某些老服务(如早期 Nginx)需 reload 才读取新值。

缓冲区与内存:别只盯着数字,要看带宽 × 延迟

盲目设 net.core.rmem_max = 16777216(16MB)可能浪费内存,也可能不够。关键公式:理想接收缓冲区 ≈ 带宽(bps) × RTT(s) ÷ 8。例如 1Gbps 带宽 + 10ms RTT → 理想缓冲区 ≈ 1.25MB。

  • 推荐配置(IDC 内网高带宽低延迟场景):
    net.core.rmem_default = 262144
    net.core.wmem_default = 262144
    net.core.rmem_max = 4194304
    net.core.wmem_max = 4194304
    net.ipv4.tcp_rmem = 4096 262144 4194304
    net.ipv4.tcp_wmem = 4096 262144 4194304
  • 必须开启:net.ipv4.tcp_window_scaling = 1(支持 >64KB 窗口)、net.ipv4.tcp_sack = 1(快速重传)

最后提醒一句:所有 sysctl 参数修改后,务必执行 sysctl -p 生效;但若涉及 net.ipv4.tcp_tw_* 类参数,已有连接不受影响,只作用于新建连接——所以压测前一定要清空旧连接,否则你以为调优成功了,其实只是缓存还在撑着。

相关专题

更多
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、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

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

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

302

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

704

2023.10.18

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

26

2025.12.30

热门下载

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

精品课程

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

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

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

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