1

我是使用https://k6.io进行负载测试的新手,并且想知道该sleep函数的行为。

现在我已经建立了一个多阶段的负载测试。在我的默认函数中,我有许多被执行的请求(get 和 post)。

我注意到,如果我只是按顺序执行几分钟,我在弹性 beanstalk 上运行的应用程序开始变慢并最终抛出 500 个错误。

但是,如果我sleep在每个请求之后添加一个语句,如下所示:


const getMe = http.get(`${appEndpoint}/me`, params)
check(getMe, {
  'me: status was 200': r => r.status == 200,
  'me: response time OK (under 500ms)': r => r.timings.duration < maxResponseTimeMs,
  });

sleep(Math.floor(Math.random() * 4) + 1)

// next request would follow below

然后我可以轻松地将虚拟用户数量增加 10 倍,而不会出现任何问题。

所以我的问题是:

确实会导致k6sleep在这段时间内暂停所有虚拟用户的所有请求,还是一次只暂停一个虚拟用户的请求。

据我了解,虚拟用户本质上只是default运行负载测试的函数的并行执行,因此整个函数会为所有用户暂停,还是针对每个用户执行此操作。

在文档中找不到有关此的任何信息,因此将不胜感激任何指针!

谢谢

4

1 回答 1

3

确实会导致k6sleep在这段时间内暂停所有虚拟用户的所有请求,还是一次只暂停一个虚拟用户的请求。

您的直觉是正确的:由于 VUdefault并行执行该功能且彼此隔离,sleep()因此调用将仅暂停该 VU 的执行。

由于您在迭代之间随机休眠 1-4 秒,因此您的服务器可能能够处理随机数量的流量,而尽可能快地发送请求,因为您的测试机器可以发送它们将导致速度变慢和 500 个错误。在测试期间,您会发现适合您系统的平衡是什么,以及最适合您的平衡。

正是由于这个原因,这种sleep()技术很有用,因此您可以控制发送的请求数量。也看看--rps选项

于 2020-04-09T10:20:49.240 回答