使用jmeter压测服务器接口,发现,无论怎么优化,都会在22000样本左右的时候,出现连接超时或者无法找到路由之类的错误。但,把错误率降低到1%一下后,找两台机器同时压,两台机器都没有出现问题,服务也正常,就说嘛。实际瓶颈并非出现在服务器上,而是在本机。

因为我使用的是mac,所以就去查了下mac的连接参数修改方法。

最大连接数限制就是系统所能打开的最大文件数(文件描述符)的限制,分全局和进程两种,相应的命令如下:

sysctl kern.maxfiles

输出:kern.maxfiles: 12288
说明:全局限制,也就是系统默认的最大连接数限制是12288

sysctl kern.maxfilesperproc

输出:kern.maxfilesperproc: 10240
说明:单个进程默认最大连接数限制是10240

sudo sysctl -w kern.maxfiles=1048600

输出:kern.maxfiles: 12288 -> 1048600
说明:设置系统最大连接数从12288到1048600

sudo sysctl -w kern.maxfilesperproc=1048576

输出:kern.maxfilesperproc: 10240 -> 1048576
说明:设置进程连接数限制,进程的最大连接数要小于等于全局连接数

ulimit命令

ulimit -n

输出:2560
说明:“ulimit -n”命令显示当前shell能打开的最大文件数,默认值:2560,该值总是小于kern.maxfilesperproc的值,因为一个shell就是一个进程。

ulimit -n 1048576

说明:设置当前shell能打开的最大文件数为1048576,该值不能大于kern.maxfilesperproc,否则会提示设置失败。

动态端口范围

sysctl net.inet.ip.portrange

输出:
net.inet.ip.portrange.first: 49152
net.inet.ip.portrange.last: 65535

Linux动态端口号默认范围是32768-65535,也就是说,作为客户端连接同一个IP和同一个端口号,最多只能建立30000多个连接,而Mac默认只能建立16000个左右的连接。

sysctl -w net.inet.ip.portrange.first=32768

说明:设置动态分配起点端口号为32768,这样可以增大客户端可以建立的连接数。

按以上的方式设置参数有个问题,当系统重启后,这些参数又恢复成了默认值,解决办法就是把参数写到/etc/sysctl.conf文件中,但是,默认这个文件是不存在的,所以首先就要创建它:

sudo touch /etc/sysctl.conf

然后把参数写到文件里

kern.maxfiles=1048600
kern.maxfilesperproc=1048576
net.inet.ip.portrange.first=49152   
net.inet.ip.portrange.last=65535

重启系统,查看结果,显示成功。

至于ulimit-n的值,可以把ulimit-n
1048576
 写到.bashrc中实现自动修改。

修改完之后,继续测试,情况好了一些,但是还是没法压出服务器性能到底怎么样,还是多找几台机器,用服务器压一压吧。

最后修改日期: 2019年4月16日

作者

留言

撰写回覆或留言

发布留言必须填写的电子邮件地址不会公开。