继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

压测软件Jmeter使用实例(WIN7环境)

胡说叔叔
关注TA
已关注
手记 472
粉丝 130
获赞 581

百科

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

我们为什么使用Jmeter

  • 开源免费,基于Java编写,可集成到其他系统可拓展各个功能插件

  • 支持接口测试,压力测试等多种功能,支持录制回放,入门简单

  • 相较于自己编写框架活其他开源工具,有较为完善的UI界面,便于接口调试

  • 多平台支持,可在Linux,Windows,Mac上运行

Jmeter安装配置

登录 http://jmeter.apache.org/download_jmeter.cgi ,根据自己平台,下载对应文件

5bd6c67d00019b1110000762.jpg

image.png

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


5bd6c67e0001524f06350499.jpg

image.png


打开后如图效果显示


5bd6c67f0001313506770442.jpg


5bd6c6800001ea4110000560.jpg


新建线程组

5bd6c6810001834410000563.jpg

线程组( Threads (Users))

  • 理解:一个虚拟用户组,线程组内线程数量在运行过程中不会发生改变。

  • 注意事项:线程间变量相互独立。一个测试计划内可以包含多个线程组。

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


    5bd6c68200017dc210000563.jpg


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


    5bd6c6830001290210000563.jpg


    其中

配置元件(Config Element)

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

HTTP请求默认值

把测试计划中所有的HTTP请求的默认配置放到HTTP请求默认值中。
把重复的内容提取出来,只需要定义一次就可以了
协议,服务器或IP地址,端口号


5bd6c68400018a6010000563.jpg


HTTP请求默认值

  • 出现在测试计划下面,那么该配置会影响测试计划下的所有HTTP请求取样器

  • 出现在线程组中,那么其影响范围是线程组。

Sampler

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

HTTP请求

理解:就是一次HTTP请求


5bd6c6850001fde710000563.jpg


本实例该配置如下


5bd6c6870001c60e10000563.jpg

监听器(Listener)

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

聚合报告

1000

image.png


1000

参数含义:

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

图形结果

1000

image.png

参数含义:

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

点击启动按钮,开启测试

1000


可见TPS还是很低的


1000

image.png

Jmeter自定义变量

配置文件


1000

1000

image.png


1000

Redis的压测

1000

自带的压测工具

629

检验服务启动状态

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


494

可以看出redis的QPS之高

467

redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100

406

只测试set,lpush命令



作者:芥末无疆sss
链接:https://www.jianshu.com/p/560c82a6333c
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP