我正在编写socket.io-client node.js机器人应用程序,以测试也在节点下运行的基于socket.io的服务器应用程序的性能.
通常,服务器运行ubuntu linux,但我在本地开发机上也安装并配置了相同的服务器应用程序(node.js,Nginx,socket.io).
如果启动bot-“ script”脚本并启动200个与服务器建立单独连接的bot,则对真正的服务器(linux服务器)也没有任何问题.
但是,如果我连接到基于本地os x的“服务器”,则无法真正超过120个连接.
我遇到了断开连接,陈旧的套接字以及断开/重新连接的无限循环的情况,在socket.io的标准设置下,完成连接(延迟的重新连接尝试)的时间将越来越长.
在这样的测试过程中,我的本地开发机几乎承受了0%的负载,因此它与内存或处理器无关.
我已经从第二台本地计算机上尝试了相同的bot脚本,以确保该问题与与服务器在同一台计算机上运行的bot无关.但是我也遇到同样的问题.
一旦我将bot脚本指向真正的服务器,我就没有任何问题.
当我处于出现问题的范围之内,即与超过120个客户端进行推送时,我尝试使用浏览器(真实的用户场景)访问我的本地开发服务器并刷新多次.有时我会收到“内部服务器500”.
让我认为也许这与Nginx无关,与socket.io不相关?还是常规OS X(非服务器)计算机上的其他一些基本套接字限制?
最佳答案
我在发布此问题之前做了所有的谷歌搜索…..
3分钟后,我偶然发现了答案:
原文链接:https://www.f2er.com/nginx/532274.html3分钟后,我偶然发现了答案:
在终端中写:
sysctl -a | grep somax
我得到了答案:
kern.ipc.somaxconn: 128
所以我猜情况已经很封闭了.
一个只需在终端中写:
sudo sysctl -w kern.ipc.somaxconn=xyz
其中xyz是允许的连接数.
在这里找到答案:
http://b.oldhu.com/2012/07/19/increase-tcp-max-connections-on-mac-os-x/