k6是GitHub上提供的开源负载测试工具。它是用Go编写的,并运行用JavaScript编写的测试脚本。它受到了开发人员,测试人员和DevOps团队的强烈兴趣,并拥有超过4400名GitHub明星。k6是命令行驱动的,测试结果输出到stdout或结果分析工具,如Load Impact Insights。

JMeter也是一个开源负载测试工具,已存在多年。它非常受欢迎,拥有数千名用户。它是一个Java应用程序,JMeter GUI用于创建测试脚本。此外,一些脚本语言可用于编写JMeter函数,包括Java,Groovy和JavaScript。Groovy已成为推荐的默认选项。但是,只能从命令行执行负载测试运行。

在“大卫与歌利亚”的方式中,让我们看一下在k6中比在JMeter中更容易做的事情的几个例子。

1.在变量中保存HTTP响应

在JMeter中:

  1. 添加Beanshell Postprocessor作为请求的子项,返回您要查找的响应。

  2. 将代码  vars.put(“response”, new String(data)); 放入PostProcessor的“脚本”区域。

  3. 请根据${response} 需要参考提取的值  。

在k6中,使用以下测试脚本代码:

let response = http.get(“http://javame.cnblogs.com/”);
在这两种情况下,数据最终都在响应变量中。主要区别在于您必须在JMeter中向请求添加Beanshell PostProcessor,然后才能添加代码段。

2.测试预期的404响应

在JMeter中:

在测试下创建一个新的Response Assertion。在断言的“要测试的响应字段”部分中,确保选中“忽略状态”框。

然后,您可以添加其他断言,例如将“要测试的响应字段”中的无线电设置为“响应代码”,并将“要测试的模式”设置为404。

图1:显示如何设置响应断言的JMeter GUI。

在k6中,使用以下测试脚本代码:

let response = http.get(“http://some.url/”);
check(res, {
"Status is 404": (r) => r.status ===
});

这里的主要区别在于,在JMeter中执行此操作需要您单击GUI并在输入字段中填入值,而使用k6则需要编写几行代码。您可以在版本控制系统(VCS)中轻松跟踪和管理k6 JavaScript加载测试代码,就像您的应用程序代码一样。

3.在不同的测试中重用自定义测试代码

例如,假设您要调用logTransaction() 150个不同测试配置中的一个文件中定义的  函数。

在JMeter中:

  1. 将该行添加  beanshell.sampler.init=BeanShellSampler.bshrc 到user.properties文件(位于JMeter安装的“bin”文件夹中)。

  2. 将logTransaction函数放在BeanShellSampler.bshrc文件中(相同位置,JMeter的“bin”文件夹)。

  3. 下次启动JMeter时,您可以在任何脚本中从任何Beanshell Sampler调用该函数。

在k6:

  1. 将logTransaction()函数放在JavaScript文件中,例如“logTransaction.js”

  2. 使用以下语句在任何脚本中导入该函数:从“/path/to/logTransaction.js”导入{logTransaction};

在k6中,任何Javascript文件都可以直接用作可导入模块,它允许您以任何方式组织文件。您还可以直接通过网络导入模块:

import { logTransaction } from "s3.amazonaws.com/path/to/logTransaction.js";
除了标准的ES6 JavaScript API之外,k6还捆绑了API来处理Cookie,加密,编码,环境变量,HTML表单,HTML解析,多部分请求,TLS客户端证书,TLS密码和版本等等。

4.实现嵌套循环

例如,您可能希望使用两个参数测试servlet:X和Y,其中X和Y是0到100之间的随机数。您需要一个嵌套循环,如下所示:

for(int  x  =   ; x  <=   ; x ++)
for(int y = ; y <= ; y ++)
servlet ?param1 = x &param2 = y

在JMeter中:

您的架构可能如下所示:

Thread Group
User Defined Variables
maxX =
maxY =
Loop Controller X
Loop Count: ${__BeanShell(Integer.parseInt(vars.get("maxX"))+)}
Counter X
Start:
Increment:
Maximum: ${maxX}
Reference Name: loopX
Loop Controller Y
Loop Count: ${__BeanShell(Integer.parseInt(vars.get("maxY"))+)}
Counter Y
Start:
Increment:
Maximum: ${maxY}
Reference Name: loopY
YOUR HTTP Request
servlet?param1=${loopX}&param2=${loopY}
. . .

在k6:

使用以下脚本代码:

for(var  x  =   ; x  <=   ; x ++)
for(var y = ; y <= ; y ++)
http.get(“http://some.domain/servlet?param1 =”+ x +“¶m2=”+ y);

当然,执行更复杂的逻辑分支是基于GUI的方法与直接在代码中编写逻辑相比经常变得非常笨重的地方。k6解决方案与用于描述问题的伪代码非常相似。

5.进行并行请求

我们通常希望并行发出多个请求,就像浏览器在获取网页时所做的那样。这使得服务器上的压力比每个虚拟用户一次只发出一个请求要多得多。

在JMeter中:

JMeter提供同步计时器,允许对请求进行分组,以便它们可以在同一时刻执行。只需在测试计划中添加同步计时器,并确保:

  • 它在两个请求中都处于同一级别

  • 线程组中的虚拟用户数> = =同步计时器中设置的数量

  • 在k6:

    使用此  http.batch() 功能可并行发出多个请求。例如:

    http.batch([
    "http://test.loadimpact.com",
    "http://test.loadimpact.com/style.css",
    "http://test.loadimpact.com/images/logo.png"
    ]);

    上述“解决方案”不具有100%的可比性。在JMeter情况下,我们仍然只允许每个虚拟用户(VU)一次发出一个请求。这意味着JMeter VU不是“真实用户”的完全准确模型。单个人类用户将使用他们的Web浏览器同时发出多个请求,而JMeter VU一次只发出一个请求。

    相反,JMeter所做的是同步VU,以便它们在同一时间发出请求。(对我来说似乎不太有用 - 总吞吐量可能会下降,因为某些VU必须等待其他VU完成请求)。

    另一方面,在所示的示例中,k6将允许每个VU打开三个并发TCP连接,因此能够并行获取这三个项目,就像Web浏览器一样。这意味着在k6情况下,100个VU可以并行获取300个项目。在Jmeter情况下,100 VU将并行获取100个项目。(注意:还有一个名为Parallel Controller的 JMeter扩展可用于创建并行请求)。

    推荐阅读:

    老王讲架构:负载均衡

    支付宝系统架构内部剖析

    大数据Spark与Storm技术选型

    【赞】用Python实现Zabbix-API 监控

    程序员怎么留住健康?

    大数据智慧平台技术方案

												

开源负载测试工具k6比JMeter更容易的5件事的更多相关文章

  1. Locust分布式负载测试工具入门

    忽略元数据末尾 回到原数据开始处 Locust简介 Locust是一个简单易用的分布式负载测试工具,主要用来对网站进行负载压力测试. 以下是github上的仓库地址 https://github.co ...

  2. HTTP/HLS/RTMP超级负载测试工具

    这个负载测试工具是网游分享的工具,可以在http://blog.csdn.net/win_lin/article/details/11835011 或者https://github.com/winli ...

  3. 2014 非常好用的开源 Android 测试工具

    http://www.php100.com/html/it/mobile/2014/1015/7495.html 当前有很大的趋势是转向移动应用平台,Android 是最广泛使用的移动操作系统,201 ...

  4. HTTP/HLS/RTMP超级负载测试工具(转)

    这个负载测试工具是网游分享的工具,可以在http://blog.csdn.net/win_lin/article/details/11835011 或者https://github.com/winli ...

  5. loadrunner(预测系统行为和性能的负载测试工具)

    LoadRunner,是一种预测系统行为和性能的负载测试工具.通过以模拟上千万用户实施并发负载及实时性能监测的方式来确认和查找问题,LoadRunner能够对整个企业架构进行测试.企业使用LoadRu ...

  6. Web API核查表:设计、测试、发布API时需思考的43件事[转]

    Web API核查表:设计.测试.发布API时需思考的43件事   当设计.测试或发布一个新的Web API时,你是在一个原有的复杂系统上构建新的系统.那么至少,你也要建立在HTTP上,而HTTP则是 ...

  7. Apache JMeter开源压力测试/负载测试工具 2.12 官方最新版

    软件介绍   Jmeter是一款使用Java开发的,开源免费的,测试工具, 主要用来做功能测试和性能测试(压力测试/负载测试),而且用Jmeter 来测试 Restful API, 非常好用. 如何学 ...

  8. 开源Web测试工具介绍

    HtmlUnitHtmlUnit 是 JUnit 的扩展测试框架之一.HtmlUnit 将返回文档模拟成 HTML,这样您便可以直接处理这些文档了.HtmlUnit 使用例如 table.form 等 ...

  9. 开源API测试工具 Hitchhiker v0.7更新 - Schedule的对比diff

    Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持脚本定制请求,可以轻松部署到本地,和你的team成员一起协作测试Ap ...

随机推荐

  1. Raiden Charge

    2017年10月22 周日 这是个元气满满 值得纪念的一天(不好意思走错片场了) 虽然有各种乱遭的客观元素 但我们队确确实实地打铁了 那些我们轻视的 野鸡(误)大学 都在我们前面 都说知耻而后勇 虽然 ...

  2. 一个开源的,跨平台的.NET机器学习框架ML.NET

    微软在Build 2018大会上推出的一款面向.NET开发人员的开源,跨平台机器学习框架ML.NET. ML.NET将允许.NET开发人员开发他们自己的模型,并将自定义ML集成到他们的应用程序中,而无 ...

  3. Redis结合Lua脚本实现高并发原子性操作

    从 2.6版本 起, Redis 开始支持 Lua 脚本 让开发者自己扩展 Redis … 案例-实现访问频率限制: 实现访问者 $ip 在一定的时间 $time 内只能访问 $limit 次. 非脚 ...

  4. [Swift]LeetCode99. 恢复二叉搜索树 | Recover Binary Search Tree

    Two elements of a binary search tree (BST) are swapped by mistake. Recover the tree without changing ...

  5. [Swift]LeetCode984. 不含 AAA 或 BBB 的字符串 | String Without AAA or BBB

    Given two integers A and B, return any string S such that: S has length A + B and contains exactly A ...

  6. Markdown语法简介

    1.标题 在想要设置为标题的文字前面加#来表示一个#代表一级标题,总共六级 2.字体 加粗要加粗的文字左右分别用两个*号包起来 斜体要倾斜的文字左右分别用一个*号包起来 斜体加粗要倾斜和加粗的文字左右 ...

  7. PostgreSQL基础知识分享

    1.架构 PostgreSQL是一个关系数据库,采用c/s架构.一个PostgreSQL会话包括: 服务端进程——postgres:用于管理数据库文件,并接受来自客户端的数据库连接, 同时代替客户端执 ...

  8. Visual Studio 2017 怎么将自动生成属性设置为旧版格式

    工具:Visual Studio 2017 1.点击工具,进入选项 2.选项窗口左侧找到C#--代码样式,点击 3.找到表达式首选项中:使用属性的表达式主体.使用索引器的表达式主体和使用访问器的表达式 ...

  9. 『离散化 discrete』

    离散化(discrete) 离散化可以说是一个很基础的算法吧,但是有些时候还是很好用很有必要的算法. 离散化的排序的一个运用,具体地讲,离散化算法是将无穷大集合中的若干个元素映射到有限大小的集合中,以 ...

  10. 从零开始学习PYTHON3讲义(八)列表类型跟冒泡排序

    <从零开始PYTHON3>第八讲 ​前面我们见过了不少的小程序,也见过了不少不同类型的变量使用的方法.但目前我们涉及到的,还都是单个的变量和单个的立即数.以变量来说,目前我们见到的,基本都 ...