【问题标题】:Stress testing in NodeJS/Socket.io for 1000 users?在 NodeJS/Socket.io 中为 1000 个用户进行压力测试?
【发布时间】:2015-10-29 03:57:24
【问题描述】:

我目前正在开发一个类似聊天的应用程序。有用户、聊天室、消息——所有这些东西。该应用由 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的限制有关?

【问题讨论】:

  • 虽然上面的帖子是重复的,但它会比请求的内容(ASP.NET)提供更多的负载测试通用信息。
  • @MeanStackeD:您可以使用 Apache JMeter 工具,您可以使用单个客户端模拟 N 个并发用户。
  • 嗯。一个外部工具会很有趣。但是,我认为我可以做一些事情,比如使用异步库一次连接多个客户端,响应这些客户端的“on”操作等。

标签: node.js socket.io stress-testing


【解决方案1】:

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

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

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

【讨论】:

  • 你有没有解决方案的存储库?
【解决方案2】:

您可以使用 Apache JMeter 工具,您可以使用单个客户端模拟 N 个并发用户。

【讨论】:

  • JMeter 可以测试 websocket 应用吗?
  • 我不确定它的可用性。当然,我想同时测试 1K 次登录,但我也有兴趣做一些事情,比如让 X 人创建 Y 个聊天室、X 人在一个聊天室中发送消息等。JMeter 真的有帮助吗?
【解决方案3】:

例如,Apache ab。

只需创建一个 API(仅用于测试目的)并使用该 API 的端点从 apache ab 发送大量消息。

ab -n 1000 -c 10 -T 'multipart/form-data; boundary=1234567890' -p post.txt  http://yourdomain.com/yourproject/api/sendmessage/

post.txt 将包含如下内容:

--1234567890
Content-Type: application/x-www-form-urlencoded
Content-Length: 30
from=myId&to=yourId&message=alrighty

<base64 data>
--1234567890

base64 data 应该是一个长字符串,表示该 POST 请求的 (base64) 数据。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-03-16
    • 2011-04-28
    • 1970-01-01
    • 1970-01-01
    • 2023-04-10
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多