压测工具哪家强,LR? jmeter?locust? wrk 全方位对比
创始人
2025-05-30 07:27:59
0

当你想做性能测试的时候,你会选择什么样的测试工具呢?是会选择wrk?jmeter?locust?还是loadrunner呢?今天,我将根据自己使用经验,针对jmeter、locust、wrk和loadrunner常用的性能测试工具进行简单介绍和对比。

首先,四者基本对比图:

由于loadrunner为商业收费模式,对于公司级测试使用而言涉及到授权问题,因此,本文暂不对loadrunner进行详细讨论。

02  wrk

wrk是轻量化的http性能测试工具,采用线程+网络异步IO模型,网络异步IO可以使得系统使用很少的线程模拟大量的网络连接以增大并发量、提高压力。

 优点:

  • 操作简单、易于使用

缺点:

  • wrk只支持http协议类型请求(如get、post等),但若是需要执行get之外的http类型请求需要使用者自行编写lua脚本;

  • 只允许单机测试,不支持多机分布式压力测试,因此wrk适合性能基准测试,对于模拟上万的用户并发测试显得有点力不从心;

  • 测试结果简单,无详细图表解析,举例如下;

wrk测试结果输出:

03  jmeter

 jmeter同样采用线程并发机制,但其主要依靠增加线程数提高并发量,当单机模拟数以千计的并发用户时,对于CPU和内存的消耗比较大。

与上述wrk相比,jmeter本身具有以下优点和缺点——

优点:

  • 界面可视化操作,可以使用录制脚本方式对较为复杂的用户流建模,还可以创建断言来验证测试行为是否通过;

  • 表格、图形、结果树等多类可视化数据分析和报告输出,举例如下;
    jmeter聚合报告及表格查看结果:

  • 支持http、ftp、tcp等多种协议类型测试;

  • 支持分布式压力测试,但对于上万的用户并发测试需要多台测试机支持,资源要求比较大;

  • 可以用于测试固定吞吐量下的系统性能,例如在100QPS(QPS:每秒查询率)下系统的响应时间和资源消耗;

缺点:

jmeter的GUI模式消耗资源较大,当需要测试高负载时,需要先使用GUI工具来生成XML测试计划,然后在非GUI模式下导入测试计划运行测试,并且关闭不需要的侦听器(收集数据与展示测量的组件),因为侦听器也会消耗掉本用于生成负载的大量资源。测试结束后后,需要将原始结果数据导入GUI以才能查看结果。

04  locust

locust是一个简单易用的分布式负载测试工具主要用来对网站进行负载压力测试。locust使用python语言开发,测试资源消耗远远小于java语言开发的jmeter。且其支持分布式部署测试,能够轻松模拟百万级用户并发测试。

与jmeter和wrk相比,locust具有以下优缺点:

优点:

  • 不同与wrk和jmeter使用线程数提高并发量,locust借助于协程实现对用户的模拟,相同物理资源(机器cpu、内存等)配置下locust能支持的并发用户数相比jmeter可以提升一个数量级;

  • 相比wrk对复杂场景测试的捉襟见肘和jmeter需要界面点击录制复杂场景的麻烦,locust只需用户使用python编写用户场景完成测试;

  • 不同与jmeter复杂的用户使用界面,locust的界面干净整洁,可以实时显示测试的相关细节(如发送请求数、失败数和当前发送请求速度等);

  • locust虽然是面向web应用测试的,但是它可以用来测试几乎所有系统。给locust编写一个客户端,可以满足你所有的测试要求;

缺点:

  • 同wrk一样,locust测试结果输出不如jmeter的测试结果展示类型多;

locust测试结果:

05  总结

本文简单介绍和对比了wrk、jmeter及locust三种性能测试工具,希望能给大家带来基础的认识。此外让我们最后一起来看看面临以下测试需求,我们应该如何在三者中进行选择:

① 我想使用界面操作的形式对我的系统做性能测试,并且希望我的测试数据有个良好的可视化展示方式;

  • 建议使用jmeter工具

② 我想要对我系统的http rest接口进行性能测试,但是我之前没有进行过任何测试,我不知道我的系统QPS是个什么样的水平;

  • 建议使用wrk工具

③ 我想对我的系统模拟用户操作进行复杂场景的性能测试;

  • 建议使用locust工具

④ 我想测试我的系统在一定QPS情况下,一段时间内的性能指标(cpu消耗、内存消耗等);

  • 建议使用jmeter工具

⑤ 我想使用匀速请求的方式,对我的系统进行性能测试;

  • 建议使用jmeter或locust工具

⑥ 我想体验编程的乐趣,自己编写脚本进行性能测试;

  • http请求:wrk,使用lua语言编写脚本;

  • locust,使用python语言编写脚本;

或者,just do it by yourself,自己选择编程语言编写性能测试脚本。

06  附录

wrk 使用参数说明:

  • 参数-c(connection,线链接数)与操作系统文件句柄数相关

    -c不能超过文件句柄数设置,开始测试前应保证系统可用端口数大于-c设置;

  • 参数-t(--thread,线程数)与操作系统cpu核数有关

    -t不宜设置过大,过大的线程数设置反而会因线程调度反而使性能降低。如下图所示,操作系统为8核cpu:相同连接数和测试时长条件下,不同线程数对同一系统REST接口测试,从测试结果可以看出当thread=8(与cpu核数一致)时系统性能测试结果最佳,性能波动最小;

 8核cpu:相同连接数和测试时长条件下,不同线程数对同一系统REST接口测试结果对比图

【资源分享】 

下面这份资源,对于想学习【软件测试】的朋友来说应该是最全面最完整的备战仓库,希望也能帮助到你!

相关内容

热门资讯

为什么科技越进步,人类却变得越... 目录 科技进步和你的轻松便利不是对等的,对等的是高层人 为什么科技越进步,人类却变得越来越忙碌
最新或2023(历届)滁州市所... 最新或2023(历届)滁州市所有的中学高中排名,滁州市最好的中学高中排行榜 滁州市高中排名:滁州市...
最新或2023(历届)黄山市所... 最新或2023(历届)黄山市所有的中学高中排名,黄山市最好的中学高中排行榜 黄山市高中排名:黄...
最新或2023(历届)安庆市所... 最新或2023(历届)安庆市所有的中学高中排名,安庆市最好的中学高中排行榜 安庆市高中排名:安庆...
最新或2023(历届)马鞍山市... 最新或2023(历届)马鞍山市所有的中学高中排名,马鞍山市最好的中学高中排行榜 马鞍山市高中排...
最新或2023(历届)铜陵市所... 最新或2023(历届)铜陵市所有的中学高中排名,铜陵市最好的中学高中排行榜铜陵市高中排名:铜陵市省级...
OMM导致tomcat引用假死 背景 在开发测试环境发现一个奇怪的情况,因查询100w条数据导致OOM,...
腾讯云GPU云服务器、CVM云... 这就是腾讯云GPU云服务器、CVM云服务器、轻量应用服务器配置价格表,最近整理的。目前...
最新或2023(历届)合肥市所... 最新或2023(历届)合肥市所有的中学高中排名,合肥市最好的中学高中排行榜合肥最新或2023(历届)...
最新或2023(历届)淮南市所... 最新或2023(历届)淮南市所有的中学高中排名,淮南市最好的中学高中排行榜 淮南市高中排名:淮...
最新或2023(历届)芜湖市所... 最新或2023(历届)芜湖市所有的中学高中排名,芜湖市最好的中学高中排行榜 芜湖市高中排名:芜湖市...
最新或2023(历届)蚌埠市所... 最新或2023(历届)蚌埠市所有的中学高中排名,蚌埠市最好的中学高中排行榜 蚌埠市高中排名:蚌埠...
最新或2023(历届)安徽省所... 最新或2023(历届)安徽省所有的中学高中排名,安徽省最好的中学高中排行榜合肥一中位居榜首  中国校...
【剧前爆米花--爪哇岛寻宝】j... 作者:困了电视剧 专栏:《JavaEE初阶》 文章分布:这...
软件测试 - 常见的开发模型和... 1.瀑布模型优点强调开发的阶段性, 强调早期计划及需求调查, 强调产品测试;缺点1. 由于瀑布模型是...
最新或2023(历届)天津市所... 最新或2023(历届)天津市所有的中学高中排名,天津市最好的中学高中排行榜下面是太阳教育网针对天津高...
最新或2023(历届)上海市所... 最新或2023(历届)上海市所有的中学高中排名,上海市最好的中学高中排行榜上海高中的大致排名   第...
最新或2023(历届)北京市所... 最新或2023(历届)北京市所有的中学高中排名,北京市最好的中学高中排行榜一、北京一流高中名单1.1...
最新或2023(历届)重庆市所... 最新或2023(历届)重庆市所有的中学高中排名,重庆市最好的中学高中排行榜  NO.1 西南师大附中...
最新或2023(历届)上海市小...     徐汇  第一梯队:世界外国语小学、爱菊小学、逸夫小学、盛大花园小学、高安路一小、向阳小学、汇...