服务器的TCP连接限制:如何优化并提高服务器的并发连接数?
创始人
2025-01-16 23:03:26
0

🌈🌈🌈🌈🌈🌈🌈🌈
欢迎关注公众号(通过文章导读关注),发送【资料】可领取 深入理解 Redis 系列文章结合电商场景讲解 Redis 使用场景中间件系列笔记编程高频电子书
【11来了】文章导读地址:点击查看文章导读!
🍁🍁🍁🍁🍁🍁🍁🍁

服务器的TCP连接限制:如何优化并提高服务器的并发连接数?

在这里插入图片描述

Linux服务器最大能打开的文件数量

在 Linux 服务器中一切皆文件,将网络接口、进程等抽象概念都视作文件,以统一的方式进行管理和操作

那么在服务器中,能打开的最大文件数量受 4 个参数影响,分别是:

  1. fs.file-max:内核参数,系统级别的限制表示整个系统可以打开的最大文件数,root 用户不会受此参数影响

  2. soft nofile:用户级别的软限制,限制单个进程上可以打开的最大文件数,soft nofile 的值比 fs.file-max 的值要小得多

  3. hard nofile:用户级别的硬限制,限制单个进程上可以打开的最大文件数,默认情况下,hard nofile 的值通常大于等于 soft nofile 的值,soft nofile 是一个警告阈值,超过了并不会阻止文件描述符的打开,而是发出警告,但是 hard nofile 是实际的最大限制,超过它将无法打开文件描述符

  4. fs.nr_open:内核参数,进程级别的限制,限制单个进程可以打开的最大文件数

    可以通过命令 sysctl fs.nr_open 查看该值大小

这三个参数之间的值大小设置需要注意以下几点:

  • hard nofile 的值大于等于 soft nofile
  • fs.nr_open 的值大于 hard nofile
  • fs.nr_open 的值不要超过系统的硬件资源限制

调整服务器能打开的最大文件数

fs.file-max 和 fs.nr_open 参数设置

通过修改 /etc/sysctl.conf 文件来修改能打开的最大文件数

vim /etc/sysctl.conf # 添加如下行 fs.file-max=1100000 // 系统级别设置成110万,多留点 buffer   fs.nr_open=1100000 // 进程级别也设置成110万,因为要保证比 hard nofile大 # 使配置生效 sysctl -p 

soft nofile 和 hard nofile 参数设置

显示当前用户的最大文件描述符限制可以使用以下命令:

ulimit -n 

这个值可以通过修改 /etc/security/limits.conf或者/etc/security/limits.d/* 的值,添加如下行:

vi /etc/security/limits.conf # 将用户级别都设置成 100w * soft nofile 1000000 * hard nofile 1000000 

一台服务器最大支持的连接数量

TCP 连接建立之后,其实就是客户端和服务器端在内存中维护的一组 socket 内核对象,只要存储 源IP、源端口号、目标IP、目标端口号

那么在理想情况下,如果只维护客户端和服务端的 socket 对象的话,最大可以建立的连接数量是由 IP + 端口号来决定的,只要 IP + 端口号不重复,那么就可以找到对应地址,建立连接,理论最大连接数量可以建立 2^32(IP数) * 2^16(端口数) ≈ 两百多亿 条连接

但是这肯定是不可能的,这么多条连接,内存也放不下呀,而且连接中如果有数据请求,需要 CPU 去处理,CPU 也处理不过来

因此最大的连接数量收到了 内存CPU 两个方面的限制

在真实场景中,有频繁的数据收发的数据处理,一台服务器可以支撑 1000 个连接就算比较好的了,在建立 TCP 连接中,服务器端的开销并不在连接的建立上,而是花在了对连接中的数据进行业务逻辑处理的过程中,这个过程是很占用 CPU 的!

一台客户机器最多可以发出多少TCP连接?

上边已经说了,建立 TCP 连接,其实就是维护一组 socket 内核对象的数据,也就是: 源IP、源端口号、目标IP、目标端口号

那么只要有其中一个元素不同,便可以区分出是不同的 TCP 连接

假设客户机器的 IP 地址不会发生变化,并且客户端只和一台 server 服务器建立 TCP 连接,那么一台客户机器可以发出的 TCP 连接的数量取决源端口号 的数量,源端口号的可用范围是 【0-65535】,所以一台客户机器对一台 server 服务器可以建立的最大 TCP 连接的数量是:65535 个连接

但是客户端的可用端口范围一般达不到 65535 个,受到了内核参数 ip_local_port_range 的影响,默认值是 32768 61000,可以通过修改 /etc/sysctl.conf 文件来调整可用端口范围:

# 修改文件 vi /etc/sysctl.conf # 添加如下内容 net.ipv4.ip_local_port_range = 32768 60999 # 使修改生效 sysctl -p 

相关问题

首先,在三次握手中,socket 的连接请求通过一个队列进行存储,队列长度通过参数 net.core.somaxconn 来控制,默认是 128,如果连接请求的数量很大,而队列长度不够,则会导致后续的连接请求被抛弃,可以通过修改此参数的值来增加存储请求的队列长度,减少服务端的请求丢失情况!

# 查看当前系统的net.core.somaxconn值 sysctl net.core.somaxconn # 修改队列长度 vi /etc/sysctl.conf # 添加如下内容 net.core.somaxconn =  # 使修改生效 sysctl -p 

相关内容

热门资讯

微扑克ai机器人(微扑克)微扑... 微扑克ai机器人(微扑克)微扑克插件(透视)本来是真的有挂(详细辅助详细教程)1、微扑克ai机器人机...
wepoke是真的有挂(透视)... wepoke是真的有挂(透视)wepoke软件机器人(详细辅助透明教程)其实是有挂(详细有挂);1、...
微扑克ai机器人(微扑克)微扑... 微扑克ai机器人(微扑克)微扑克有辅助插件吗(透视)其实是有挂(详细辅助技巧教程)1、微扑克ai机器...
WePoKe透视挂(透视)we... WePoKe透视挂(透视)wepower透视辅助(详细辅助大神讲解)确实是真的有挂(专业外 挂)1、...
微扑克辅助软件(微扑克)微扑克... 微扑克辅助软件(微扑克)微扑克辅助工具(透视)都是有挂(详细辅助透视教程);1、构建自己的微扑克辅助...
wepoke黑科技(透视)we... wepoke黑科技(透视)wepoke黑科技是啥(详细辅助必胜教程)确实存在有挂(科普透视挂)1、w...
微扑克ai辅助工具(微扑克)w... 微扑克ai辅助工具(微扑克)wpk微扑克外挂事件(透视)真是有挂(详细辅助切实教程);1、微扑克ai...
wepoke插件(透视)wep... wepoke插件(透视)wepoke怎么使用模拟器(详细辅助新2025版)一直是真的有挂(教你外 挂...
wepoke确实有挂(透视)w... wepoke确实有挂(透视)wepoke ai代打(详细辅助攻略教程)确实是真的有挂(科普透明挂);...
微扑克辅助挂(微扑克)微扑克网... 微扑克辅助挂(微扑克)微扑克网页版辅助(透视)一直存在有挂(详细辅助辅助教程)1、玩家可以在微扑克辅...