博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
压测软件Jmeter使用实例(WIN7环境)
阅读量:5920 次
发布时间:2019-06-19

本文共 2001 字,大约阅读时间需要 6 分钟。

百科

Apache JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。 它可以用于测试静态和动态资源,例如静态文件、Java 小服务程序、CGI 脚本、Java 对象、数据库、FTP 服务器, 等等。JMeter 可以用于对服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。另外,JMeter能够对应用程序做功能/回归测试,通过创建带有断言的脚本来验证你的程序返回了你期望的结果。为了最大限度的灵活性,JMeter允许使用正则表达式创建断言

我们为什么使用Jmeter

  • 开源免费,基于Java编写,可集成到其他系统可拓展各个功能插件
  • 支持接口测试,压力测试等多种功能,支持录制回放,入门简单
  • 相较于自己编写框架活其他开源工具,有较为完善的UI界面,便于接口调试
  • 多平台支持,可在Linux,Windows,Mac上运行

Jmeter安装配置

登录 ,根据自己平台,下载对应文件

img_5eefcedb4b5e0bea0e5f303fd7578c06.png
image.png

将下载Jmeter文件解压,打开/bin/jmeter.bat

img_d26c0336bddf4a3ccb77563103e2a6b3.png
image.png

打开后如图效果显示

img_2812efb953822d000c006c6136360f09.png
img_a500f237859be403072c6ea051ed2a34.png
新建线程组
img_33d90009260f0f96fbcfb7c6a52a8164.png

线程组( Threads (Users))

  • 理解:一个虚拟用户组,线程组内线程数量在运行过程中不会发生改变。
  • 注意事项:线程间变量相互独立。一个测试计划内可以包含多个线程组。
  • 可定义内容:

    取样器错误后执行的操作:继续,启动下一个线程,停止线程,停止测试,立刻停止
    线程属性:线程数,启动间隔时间(s)(n s内启动所有线程),单线程循环次数,线程执行顺序,是否使用调度器。
    调度器配置:持续时间,启动延迟,启动时间,结束时间
    本实例基本设置如下

    img_9d6a14a4eaa877a3536e357b6eb4ba3e.png

    为该线程组添加HTTP请求默认值

    img_80ea8afd0212961e18636d652913a551.png
    其中

配置元件(Config Element)

理解:为测试提供数据支持的控件

HTTP请求默认值

把测试计划中所有的HTTP请求的默认配置放到HTTP请求默认值中。

把重复的内容提取出来,只需要定义一次就可以了
协议,服务器或IP地址,端口号

img_3313324779c687b7b9204d80bb2086e5.png

HTTP请求默认值

  • 出现在测试计划下面,那么该配置会影响测试计划下的所有HTTP请求取样器
  • 出现在线程组中,那么其影响范围是线程组。

Sampler

理解:请求,设置不同的request

HTTP请求

理解:就是一次HTTP请求

img_5e5b8425daa98b4e926d9cb2a3e8ac7c.png

本实例该配置如下

img_0fa94cd4548ef19f9791fa3ebe003f3b.png

监听器(Listener)

理解:查看请求执行结果的控件

聚合报告

img_cce2ef38f02767a759b58d4fe3fb8e23.png
image.png
img_513d48da8da9f761b58f7b5457ecdfd0.png

参数含义:

Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值

Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,也可以以Transaction 为单位显示平均响应时间
Median:中位数,也就是 50% 用户的响应时间
90% Line:90% 用户的响应时间
Min:最小响应时间
Max:最大响应时间
Error%:本次测试中出现错误的请求的数量/请求的总数
Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数
KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

图形结果

img_e4839483bb7663454e8fccbbe205dde9.png
image.png

参数含义:

样本数目:总共发送到服务器的请求数。

最新样本:代表时间的数字,是服务器响应最后一个请求的时间。
吞吐量:服务器每分钟处理的请求数。
平均值:总运行时间除以发送到服务器的请求数。
中间值:代表时间的数字,有一半的服务器响应时间低于该值而另一半高于该值。
偏离:服务器响应时间变化、离散程度测量值的大小,或者,换句话说,就是数据的分布。
注意事项:图形结果本身会影响Jmeter的性能

点击启动按钮,开启测试

img_2927420e69eaf0a6bacbec45217cae2c.png

可见TPS还是很低的

img_d3048439cb36e9014c290c0998cce21f.png
image.png

Jmeter自定义变量

配置文件

img_0135a112e9106bab231243aaaea02c64.png
img_c5dd445a13fdb0198c18aaa493f12437.png
image.png
img_50d6470e8ec3b59e0ef8a9c619c0b059.png

Redis的压测

img_7528faedbbe773466c500507f9b73fd6.png
自带的压测工具
img_f5ec81c9f3cc7f7c409108c61f5a2d03.png
检验服务启动状态

执行redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 100000命令后

img_504be98a73960af988ec48563c8666d8.png
可以看出redis的QPS之高
img_2292f66ef334daa7c6ec91ae930d9527.png
redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100
img_9cfbfd0a30a14f9dfabcab4b3972c66c.png
只测试set,lpush命令

转载地址:http://isbvx.baihongyu.com/

你可能感兴趣的文章
C#开发微信门户及应用(12)-使用语音处理
查看>>
与Win8之磁盘活动时间100%斗争心得
查看>>
u盘的一些理解
查看>>
堆区和栈区的区别【转】
查看>>
【Unity3d】火炬之光的X射线效果
查看>>
谈谈GUI的配色和字体选择
查看>>
一个load飙高的过程分析,非常有价值(转)
查看>>
Unity Svn(转)
查看>>
opencv3-core之基本操作
查看>>
关于牛逼的顺丰--也谈管理
查看>>
Html5 舞动的雨伞
查看>>
BZOJ2757 : [SCOI2012]Blinker的仰慕者
查看>>
.Net学习心得
查看>>
mysql 的 find_in_set函数使用方法
查看>>
Maven学习 (一) 搭建Maven环境
查看>>
【转】产品整合比创造更重要
查看>>
linux之fork()函数详解
查看>>
【持续更新】总结:C++开发时积累的一些零碎的东西
查看>>
mysql 正则
查看>>
最精简 代理代码
查看>>