node.js - 在 NodeJS/Socket.io 中对 1000 个用户进行压力测试?

标签 node.js socket.io stress-testing

我目前正在开发一个类似聊天的应用程序。有用户、聊天室、消息——所有这些东西。该应用程序由 Node.js 和 Socket.IO 提供支持。

不过,我感兴趣的一件事是对应用程序进行压力测试。当前存在的测试只是一些使用 1 个客户端的功能测试。但是,我想做一些事情,比如测试 1000 人同时登录应用程序,很多人进入聊天室,每个人都在那个房间里发送消息,等等......

我该怎么做呢? Google 搜索似乎带来了不相关的结果。

我注意到有些人认为这是重复的。但是,那个问题涉及到ASP.NET,使用Selenium是不行的。此外,我原本打算获得涉及在 node.js 框架内执行特殊操作的答案。另一位开发人员(不再是团队的一员)编写了一些压力测试,涉及定义自定义用户对象并迭代地注册这些用户、加入房间等。这些测试不完整且不再可用,因为代码库中的许多内容已更改因为他们是写的。无论如何,以某种方式允许以另一种方式对应用程序进行压力测试的答案是可以接受的。

编辑:这是我对许多用户进行压力测试的尝试。

function client() {
   // Define a testing client that responds to socket io events and the like
}

...
testers = [];
for (int i = 0; i <= 1000; i++) testers.push(new client());
// Each client connects to server with option 'force new connection: true'

it('Should login many users simultaneously') {
    // Use async.each on testers
    // Use client.login() on each client.
}

我发现这是有问题的。在登录大约 250 个用户后,测试根本就没有进行。这里的问题是什么?会不会是node.js和socket.io的局限性?

最佳答案

我和我的团队最终采用的解决方案如下:

我们在其自己的文件 (client.js) 中定义了一个 Client 对象,其中定义了各种 Action 和事件以响应 Socket.IO on 事件等。在 test.js 文件中,我们将实例化一个 Client 对象的许多实例,创建许多连接和客户端。

我们遇到的限制可能涉及运行测试的计算机的功能(不过,托管服务器的设备可以运行 1000 个用户的测试)。

关于node.js - 在 NodeJS/Socket.io 中对 1000 个用户进行压力测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31848360/

相关文章:

javascript - Jmeter:恒定吞吐量计时器值每五分钟更改一次

windows - 在我的负载测试期间,一个 Windows 客户端可以模拟多少个线程/用户?

node.js - 是否有可能以某种方式在 NodeJS 中进行多线程处理?

node.js - OpenShift 上使用 Node.js、express 和 socket.io 的 Access-Control-Allow-Origin

javascript - 如何连接到 "host:port"但不使用浏览器,仅使用 Node js/Javascript?

javascript - 在纯 Javascript 中创建 Canvas /位图(无 html)

flash - 我如何为 Flash 游戏执行负载/压力测试?

javascript - 通过mongodb文档的property进行映射

node.js - 传入参数的异步 waterfall

node.js - npm install lite-server --save-dev 错误