理论单服可承载最大TCP连接数:2的48次方=2.81474976710656E14,即ip数(2的32次方)*ip数(2的16次方)个连接,但实际上连接数还受机器硬件配置的限制,所以,在部署服务器时,根据需要调试出你认为可以接受的范围即可。
------------优化服务器单服可承载的最大tcp连接数
在linux中,开启tcp连接实际上就是打开文件句柄,所以,可以打开多少文件句柄,就可以创建多少tcp连接。
----------全局配置,所有进程共享的上限
查看系统配置最大句柄数 cat /proc/sys/fs/file-nr
修改: /etc/sysctl.conf
fs.file-max = 1000000
net.ipv4.ip_conntrack_max = 1000000
net.ipv4.netfilter.ip_conntrack_max = 1000000
---------单进程配置,单个进程独立的上限配置
查看最大进程数 ulimit -u
查看各种系统限制 ulimit -a
查看进程最大句柄数 ulimit -n
修改:/etc/security/limits.conf
*(所有用户) soft(软限制) nofile(单进程可打开最大句柄) 1000000
* hard(硬限制) nofile 1000000
* soft nopro(最大进程数) 1000000
* hard nopro 1000000
在tcp连接的四次挥手过程中,有一个固定的连接断开等待时间配置,如果这个时间过长,就会造成大量等待断开链接状态的资源堆积,所以,调试出一个合理的等待时间,可以有效增加无效链接所占资源的回收利用。
----------linux优化tcp连接存活时间,关闭连接时等待时间
修改/etc/sysctl.conf,添加如下几行:
#改系統默认的TIMEOUT时间
net.ipv4.tcp_fin_timeout=2
#启重用,允许将TIME_WAIT sockets重新用于新的TCP连接 默认为0表示关闭
net.ipv4.tcp_tw_reuse=1
#开启TCP连接中TIME_WAIT sockets的快速回收 默认为0 表示关闭
net.ipv4.tcp_tw_recycle=1
以上就是linux服务器的一些配置上的优化。
下面是使用windows作为客户端进行压力测试时,增大可创建tcp链接数的配置。
----------windows优化tcp连接关闭的四次握手中的等待时间,优化可用端口数
对于windows环境,可通过修改注册表进行配置:
\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters
添加一个DWORD类型的值TcpTimedWaitDelay,值可以根据实际情况配置。十进制 单位秒 最少30秒,最多300秒
\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\TCPIP\Parameters
添加一个DWORD类型的值MaxUserPort ,值可以根据实际情况配置。十进制 大概60000多点是上限
通过上面的配置,我在本机测试的时候,本机同时作为服务器和客户端,可以创建到30000连接,再加上同事机器的20000连接,一共5万多的连接是上限,再多机器就受不了了,跑满内存,cpu跑满,我的机器配置是8G内存,4核,测试代码只是纯创建连接保持连接,发送消息,输出消息。
如果使用tomcat作为服务器容器的话,tomcat也限制了最大连接数,通过下面的server.xml配置可以修改最大链接数。
配置tomcat最大连接数
protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443" />