Jmeter接口压测快速入门

[TOC]


Jmeter简介

Jmeter是Apache开源的一个使用纯Java编写的压力测试工具,它最初是为测试web应用程序而设计的,但后来扩展到了其他测试功能。例如,可用于测试静态和动态资源以及web动态应用程序的性能等。Jmeter可以用来模拟对服务器、服务器组、网络或对象上的重负载,以测试其强度或分析服务在不同负载类型下的总体性能。

如今Jmeter是一个主流的、功能完善且强大的压测工具,由于是使用Java编写的,所以具有跨平台特性,可以运行在Windows、Mac、Linux等操作系统上。并且支持丰富的协议,如:HTTP/HTTPS、FTP、JDBC、SOCKET、SOAP。。。等,此外还有许多第三方插件支持以及第三方集成

相关网址:


配置Jmeter的测试计划

通过以上给出的地址将Jmeter下载好后,进入到Jmeter的bin目录下,启动脚本放在这个目录,其中windows双击jmeter.bat即可,Mac和Linux下则是使用如下命令运行:

sudo sh {JMETER_HOME}/bin/jmeter.sh

初次运行可能会比较慢,启动成功后,界面如下:


image.png

接下来我们看看如何使用Jmeter对接口进行压测,我现在有一个商品列表接口,接口路径为:/goods/to_list

想要使用Jmeter对这个接口进行压测的话,首先右击左边栏的“Test Plan”(测试计划),添加一个“Thread Group”(线程组),如下图所示:


image.png

接着简单配置一下请求线程数之类的,线程数就代表着并发数:


image.png

因为该接口是通过HTTP请求的,所以需要添加一个HTTP请求默认值,如下图:


image.png

配置接口服务的请求协议、ip地址以及端口号,这样后面添加HTTP请求的时候就不需要重复填写这些信息了,可以起到一个通用配置的作用:


image.png

然后添加一个HTTP请求:


image.png

这里只需要配置接口路径以及请求方法即可,因为Jmeter会自动帮我们拼上之前配置的HTTP请求默认值:


image.png

为了查看测试结果,还需要添加一些监听器,监听器有很多种,也可以添加多个,这里我添加了一个聚合报告:


image.png

以及一个图形结果:


image.png

开始测试

在上一小节中,介绍了如何针对一个现有的接口配置测试计划,按照以上步骤配置完成后如下:


image.png

现在我们就可以开始执行这个测试计划了:


image.png

测试运行完成后,可以在聚合报告中看到压测的统计数据:


image.png

简单说明下这些统计指标:

  • Samples:采样数/请求数
  • Average:平均响应时间,单位毫秒
  • Median:响应时间的一个中间值,单位毫秒
  • 90%Line:90%的请求响应时间,单位毫秒
  • 95%Line:95%的请求响应时间,单位毫秒
  • 99%Line:99%的请求响应时间,单位毫秒
  • Min:请求最小响应时间,单位毫秒
  • Maximum:请求最大响应时间,单位毫秒
  • Error %:响应错误率
  • Throughput:每秒的吞吐量
  • Received KB/sec:每秒接收的数据量
  • Send KB/sec:每秒发送的数据量

如果此时查看图形结构的话,会发现只有一点点线条,这是因为我们将线程组的线程数设置太小了:


image.png

可以尝试将线程数设置到1000,然后清除之前的测试报告数据:


image.png

然后再运行这个测试计划,运行完成后再打开图形结果就可以看到曲线图了,如下:


image.png

命令行压测

以上小节介绍了Jmeter的基本使用,但都是基于可视化界面操作的。在某些情况下我们可能需要在服务器上进行测试,而绝大多数服务器系统都只有命令行。好在Jmeter支持命令行下的操作,所以本小节将介绍在命令行下如何使用Jmeter做压测。

首先第一步是在当前的操作系统下在可视化界面上配置好测试计划并将其存储为jmx文件,在这一步我们直接将之前所演示的测试计划另存为jmx文件即可。“file” -> “Save Test Plan as”:


image.png
  • Tips:jmx文件内容格式为xml,实际上就是描述了测试计划的配置信息,感兴趣的话可以自行打开瞧一瞧

第二步是将这个jmx文件上传到服务器上,我这里的操作系统是Mac OS,所以使用scp进行上传:

scp MyWorkSpace/TestFiles/goods_list.jmx root@${server_ip}:/home/goods_list.jmx
  • Tips:如果是windows系统,可以使用rz命令,直接选择上传的文件即可。

上传完成后,使用Jmeter的shell脚本jmeter.sh执行该jmx文件:

[root@server ~]# cd /usr/local/apache-jmeter-5.1.1/bin/
[root@server /usr/local/apache-jmeter-5.1.1/bin]# ./jmeter.sh -n -t /home/goods_list.jmx -l /home/result.jtl

参数说明:

  • -n:非图形界面启动
  • -t:指定需要执行的jmx文件路径
  • -l:指定结果文件的存储路径

执行该测试计划后,想要知道压测是否正常进行的话,可以使用top命令查看系统负载。我这里很明显是正常执行压测了,CPU负载达到了19.72

image.png

执行结束后会输出一些测试结果的统计信息:


image.png

正常情况下执行结束会生成一个测试结果文件,存放在我们使用参数-l指定的路径下。如下:

image.png

最后把生成的result.jtl文件下载到本地,并导入到Jmeter中。“Aggregate Report” -> “Browser” -> “Open”:

image.png

此时就可以看到测试结果的聚合报告了:


image.png

自定义变量模拟多用户

上面两小节我们简单介绍了Jmeter的基本使用,而本小节则将介绍一个在Jmeter中很实用的功能:自定义变量。有过一些测试经验的小伙伴应该知道在很多接口的测试用例下,我们可能需要模拟多个用户对某一接口进行请求,这时候通过使用Jmeter里的自定义变量就能实现这个功能。当然自定义变量不仅仅是用来模拟多用户,这里只是举一个实际的应用例子。

在一个线程组里可以添加多个HTTP请求,如果希望一次只测试一个接口的话,可以将其他测试请求给禁用掉。例如这里将之前所添加的“商品列表”给禁用,右击“商品列表”选择“Disable”:


image.png

现在我有一个可以通过token获取用户信息的接口:/user/info,该接口需要接收一个参数,即用户的登录token。根据该接口添加一个新的HTTP请求,具体配置如下:

image.png

按照如此配置,每次请求传递的都是同一个token,这样就只能针对一个用户进行测试。若要模拟多用户,自然不能将token写死在这里,而是将其抽取成一个变量,这也就是所谓的自定义变量了。在Jmeter中自定义变量,首先需要添加一个“CSV Data Set Config”。如下图所示:


image.png

然后创建一个配置文件,配置文件的内容是有一定格式的,需要使用分隔符分隔,分隔符可以是任意的可识别符号,例如我这里使用逗号进行分隔:

$ cat config.txt
13000000001,149787a6b7986f31b3dcc0e4e857cd2a
13000000002,078563f337ec6d6fedf131ddc857db19
13000000003,7692dcdc19e41e66c6ae2de54a696b25
13000000004,0f3e84acb19dff22f695f31dbe3e972a
13000000005,268e27056a3e52cf3755d193cbeb0594
13000000006,00c66aaf5f2c3f49946f15c1ad2ea0d3

接着根据配置文件和实际需求编辑如下选项,让Jmeter可以从配置文件中读取配置项:


image.png
  • Tips:这里定义的变量名中userId对应的是配置文件中的第一列,而token则是对应的第二列,以此类推。另外,分隔符必须与配置文件中的分隔符保持一致,这样Jmeter才能正常构建变量与配置的映射关系

在使用的时候,通过${变量名}引用自定义变量即可,如下示例:

image.png

这样Jmeter就会从配置文件中读取不同的token并赋值给我们定义好的变量,那么每次请求就可以传递不同的token,以达到模拟多个用户请求的效果。


在上一小节中我们介绍过命令行下的压测方式,但如果我们配置的测试计划用到了自定义变量, 且定义了配置文件的路径。而服务器上的文件路径肯定和本地操作系统的文件路径不一样,那么要如何更改配置文件的路径呢?

首先将jmx文件和配置文件一并上传到服务器上,接着打开jmx文件并查找到CSVDataSet标签,然后将描述配置文件路径的子标签的值改为服务器上配置文件所在的正确路径即可。如下图所示:

image.png


Redis压测工具 - redis-benchmark

Redis作为缓存中间件,其性能瓶颈会影响到系统的整体性能,所以通常我们也需要通过压测的方式确定Redis服务的性能瓶颈是多少。而Redis自带了压测工具:redis-benchmark,本小节将简单介绍该工具的使用。

该工具的使用也比较简单,如果只是做一个压测的话,只需要使用如下命令即可:

[root@server ~]# redis-benchmark -h 127.0.0.1 -p 6379 -c 100  -n 100000

参数说明:

  • -h:指定host,即redis服务所在的ip地址
  • -p:指定端口号
  • -c:指定并发请求数量
  • -n:指定发送多少个请求

执行该命令后,控制台会输出相应的压测结果。观察输出的信息会发现,该命令会逐个对redis的一些主要指令进行压测,我这里就截取了get指令的压测结果。如下:

====== GET ======
  # 10w个请求在1.58秒内执行完毕
  100000 requests completed in 1.58 seconds
  # 100个并发客户端
  100 parallel clients
  # 每个请求数据包大小为3字节
  3 bytes payload
  keep alive: 1

# 48.00%的请求耗时小于等于1毫秒
48.00% <= 1 milliseconds
# 99.66%的请求耗时小于等于2毫秒
99.66% <= 2 milliseconds
# 100%的请求耗时小于等于2毫秒
100.00% <= 2 milliseconds
# 每秒可完成63411.54个请求,即QPS
63411.54 requests per second

如果希望压测时指定每个请求的数据包大小可参考如下命令:

[root@server ~]# redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100

参数说明:

  • -q:表示quiet,即不输出详细信息,仅输出每个指令的QPS信息
  • -d:指定每个请求的数据包大小,单位为字节

如果只想压测指定的命令,则可以使用-t参数来指定,如下示例:

[root@server ~]# redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush  -q -n 100000

如果想压测某条具体的指令,那么则可以使用script load来指定脚本。如下示例:

[root@server ~]# redis-benchmark -h 127.0.0.1 -p 6379 -q -n 100000 script load "redis.call('set', 'foo', 'bar')"
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容