系统网站哪个好,网络教学网站建设,安卓系统谁开发的,专业平台建设目前最新版本发展到5.0版本#xff0c;需要Java7以上版本环境#xff0c;下载解压目录后#xff0c;进入\apache-jmeter-5.0\bin\#xff0c;双击ApacheJMeter.jar文件启动JMemter。
1、创建测试任务
添加线程组#xff0c;右击测试计划#xff0c;在快捷菜单单击添加-…目前最新版本发展到5.0版本需要Java7以上版本环境下载解压目录后进入\apache-jmeter-5.0\bin\双击ApacheJMeter.jar文件启动JMemter。
1、创建测试任务
添加线程组右击测试计划在快捷菜单单击添加-》线程(用户)-》线程组。设置线程组主要包含三个参数线程数、Ramp-Up、循环次数。 线程数设置虚拟用户数。一个虚拟用户占用一个进程或线程。线程数就相当于虚拟用户数。
Ramp-Up设置的线程数启动时长单位为秒。如果线程数为100准备时长为20秒那么需要20秒启动100个线程平均每秒启动5个线程。
循环次数每个线程发送请求的个数。如果线程数为100循环次数为2那么每个线程发送2次请求总请求数为100*2200次。如果勾选了“永远”复选框那么所有线程会循环发送请求直到手动单工具栏停止按钮或者设置的线程运行时间结束才会停止运行。
这次针对接口测试默认都为1就行。
2、添加get的HTTP请求
右击线路组在快捷菜单单击添加-》取样器-》HTTP请求。 协议向目标服务器发送HTTP请求时的协议可以是HTTP或HTTPS默认不填为HTTP。
服务器IP和端口输入目标服务器地址和端口号。
内容编码默认值为iso8859
方法针对请求方法选择
路径输入请求目标地址
参数录入查询的参数数值
3、添加post的HTTP请求
方法同上只是请求方法不同这次改用POST传递参数向服务器及POST请求的URL地址。 根据开发提供的接口文档参考传入参数选项录入进去。
4、添加断言
分别右击发布会查询信息和添加发布会信息添加-》断言-》响应断言
这次选择响应文然后录入需要匹配的数据。 5、添加察看结果树
右击发布系统项目单击添加-》监听器-》察看结果树运行后 成功显示绿色标志失败显示红色标示可以查看到每个用例返回的数据。
6、添加用表格察看结果 可以更详细查看到耗时及字节大小结果状态用例信息。
JMeter性能测试
由于JMeter支持录制不够好现在常用的方法是使用Badboy录制,生成JMeter脚本,然后用JMeter打开,添加监听器来查看结果。
双击软件图标开启badboy即可看到以下界面 1、开始录制
在地址栏(图中用红色框住部分)中输入你需要录制的Web应用的URL,并点击红圆点按钮开始录制。开始录制后,你可以直接在Badboy内嵌的浏览器(主界面的右侧)中对被测Web应用进行操作,所有的操作都会被记录在主界面左侧的编辑窗口中如下图所示 将脚本导出为jmeter 线程数代表发送请求的用户数目Ramp-up periodinseconds代表每个请求发生的总时间间隔单位是秒。假如我的请求数目是5而Ramp-up periodinseconds参数是10那么每个请求之间的间隔就是 105也就是2秒。如果Ramp-up periodinseconds设置为0就代表并发请求。
最后清除循环次数的复选项“永远”然后输入。这个值是告诉JMeter你的测试重复多少次。如果你输入1那么JMeter只会运行一次测试。要不停的运行你的测试计划选中“永远”复选框。
如下图摸拟1000个并发用户数量运行一次登录测试。 2、添加监控
这个主要是用来查看测试结果用的可以以不同形式展现这里举例说明添加监听器用表格查看结果、聚合报告和图形报告thread Group-添加-监听器-聚合报告图形报告、用表格查看结果如下图所示 程序运行完成以后就可以查看相应的测试结果这里以1000个线程组瞬时并发为例得到如下报告 上图表参数含义如下 1、样本数目是总共发送到服务器的请求数。 2、最新样本是代表时间的数字,是服务器响应最后一个请求的时间。 3、吞吐量是服务器每分钟处理的请求数。 4、平均值是总运行时间除以发送到服务器的请求数。 5、中间值是代表时间的数字有一半的服务器响应时间低于该值而另一半高于该值。 6、偏离表示服务器响应时间变化、离散程度测量值的大小或者换句话说就是数据的分布。
可以看出当1000人瞬时并发时平均响应时间为1630ms吞吐量为3,940.887/分钟平均响应中值为230ms。 图表含义说明如下
Label说明是请求类型如HttpFTP等请求。
#Samples也就是图形报表中的样本数目总共发送到服务器的样本数目。
Average也就是图形报表中的平均响应时间是总运行时间除以发送到服务器的请求数。
Median也就是图形报表中的中间值50%用户响应时间有一半的服务器响应时间低于该值而另一半高于该值。
90%line是指90%请求的响应时间比所得数值还要小也就是90%用户的响应时间。
Min是代表时间的数字,是服务器响应的最小时间。
Max: 是代表时间的数字,是服务器响应的最大时间。
Error%:请求的错误百分比。本次测试中出现错误的请求的数量/请求的总数。
Throughput:也就是图形报表中的吞吐量这里是服务器每单位时间处理的请求数注意查看是秒或是分钟。默认情况下表示每秒完成的请求数。
KB/sec:每秒从服务器端接收到的数据量。
要所得的数据为正确聚合报告error%必须为0.00%,否则说明用户没有全部通过测试这里得到平均响应时间1630ms平均响应中中值为230ms
上图Error出现错误所得的数据不是准确从日志和表格来看中间过程发生连接请求超时在响应时间内接收请求数响应时间为。如下图所示 在测试过程中平均响应时间、吞吐量、并发连接数是我们性能测试的一个重要衡量指标但是在测试中特别是在聚合报告中得出的90%Line等同于该用户提出的90%响应时间,这个数值对我们性能测试分析也很有参考价值。90%响应时间是说在发送的请求中90%的用户响应时间都比得到的数值上要短同时说明一个系统在应用时90%的用户响应时间都能达到这个数值那么就为系统性能分析提供了很好的参考价值。
如果把线程数改为500并发连接请求结果Error不会出现错误所得到性能测试数据准确。 总之需要不断的调优对比数据接近最佳状态确定负载达到多少并发数量。
最后感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走 这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你