修改Mac的最大连接数、端口数(Too many open files )

本文详细介绍了在Mac系统上使用JMeter进行服务器接口压力测试时遇到的连接数限制问题及解决方案,包括调整系统最大文件描述符数量、动态端口范围等关键参数,以提升压测效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用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-n1048576 写到.bashrc中实现自动修改。

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

### 解决 MongoDB 启动时报错 "Too many open files" 当遇到 `Too many open files` 的错误提示时,这通常意味着操作系统级别的文件描述符限制过低。为了有效解决问题并确保 MongoDB 能够稳定运行,建议采取以下措施: #### 修改 Linux 文件描述符限制 通过编辑 `/etc/security/limits.conf` 来增加用户可打开的大文件限制。具体操作如下所示[^5]: ```bash * soft nofile 65536 * hard nofile 65536 * soft nproc 65536 * hard nproc 65536 ``` 上述设置将软硬限制均调整至较高水平(例如 65536),从而减少因资源不足引发的服务中断风险。 #### 配置 MongoDB 参优化 对于 MongoDB 自身而言,在配置文件中适当设定日志记录路径和其他参有助于提高性能与稳定性。参考样例配置片段如下[^2]: ```yaml systemLog: destination: file logAppend: true path: "/path/to/log/file" storage: dbPath: "/path/to/db/directory" processManagement: fork: true net: port: 27017 bindIp: "0.0.0.0" ``` 请注意替换实际的日志存储位置以及据目录地址,并确认这些路径具有足够的权限供 MongoDB 使用。 #### 检查现有连状态 有时过多未关闭的客户端连也会触发此类警告。可以利用命令行工具来监控当前活动会话量及其占用情况: ```bash ss -ant | grep ESTAB | wc -l ``` 此指令能够统计处于建立状态下的 TCP 连;如果值异常偏高,则需进一步排查是否有程序未能正常释放已使用的端口或套字。 #### 日常维护注意事项 为了避免未来再次遭遇相同问题,日常运维过程中应注意定期清理不再需要的据文件、合理规划磁盘空间分配策略,并保持软件版本更新以便获取新的安全补丁和技术改进[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值