JMeter使用指南+实验报告
JMeter使用指南
编辑时间:2024/3/30 12:46
界面基本配置方法
每次重启软件时都需要重新设置
1.选项里的放大与缩小——缩放字体
2.选项里的选择语言
3.命令行的调出
我记得英文版可以通过按一个像小扳手的按钮调出,通过它可以比较迅速地发现是“time out”这种超时问题,还是已经正确运行了。
注意事项
1.文件新建时同时要注意结构~
这边我有踩雷~我是设置线程组必须为TCP取样器的上一级,下面的三个报告为TCP取样器的下一级,才可以输出结果文件,如果把他们设置为同级,就无法生成有有效内容的结果文件。
2.EOL的设置
超时会报500错误,如果你没有设置End of line的话,会在读取流的时候无限阻塞,直到超时,报500错误!
解决方法:设置End of line(后面直接称eol),eol是文本结束符,是说的返回的响应数据最后一位。
Jmeter报错org.apache.jmeter.protocol.tcp.sampler.ReadException - ycyzharry - 博客园 (cnblogs.com)
3.汇总报告/聚合报告里的指标时累积的
当前面的结果异常时,要每次点“扫帚”按钮清除,避免前面的异常取样结果算到整体百分比里。
4.当输出中含有中文时,记住修改文件编码形式
原来的编码形式为GBK,导致我前面的中文输出结果总是无法正常显示,后面我修改了在bin目录里的jmeter.properties配置文件,把编码设置为UTF-8(tcp.charset=UTF-8),把那行注释取消掉,重启软件,实现了中文输出的正确显示。
5.想要打开JMerter方法
双击运行bin里的JMERT.bat文件,界面会自动打开。
一些指标介绍
1.TCP取样器
属性 | 描述 | 必要? |
---|---|---|
Name | 展示在右侧树形列表的名称 | 默认就有 |
TCPClient classname | 表示处理请求的实现类,默认是TCPClientImpl ,对应属性设置名为tcp.handler | 不是 |
ServerName or IP Port Number | 服务器 主机名,ip地址 端口号 | 是 |
Re-use connection | 如果选中,这个链接处于保持打开状态,不选中就是读取数据后就关闭 注意这个不是必须要打开,我在设置它时踩雷了 | 是 |
Close connection | 如果选中,这个链接将会在运行中取样器之后被关闭 | 是 |
SO_LINGER | enable/disable(启用/禁用)SO_LINGER设置特定的值,单位为秒,它线性创建套接字,如果你是设置的值为0,你可以避免大量套接字处于TIME_WAIT (等待状态) | 不是 |
End of line (EOL) by value | 表示一行结束符,如果设置值在-128到127之外将会跳过eol 检查,你可以在jmeter.properties文件中增加属性eolByte进行设置,如果你在TCP Sampler Config(TCP 取样器配置)中也设置这个属性,那么TCP Sampler Config 中设置的将会奏效 这个比较重要,必须设置 | 不是 |
Connect TimeOUt | 连接超时(单位毫秒,0 表示禁用超时) | 不是 |
Response Timeout | 连接超时(单位毫秒,0 表示禁用超时) | 不是 |
Set NoDelay | 可以参考java.net.Socket.setTcpNoDelay(),如果选中,它将会禁用Nagle's算法(利用缓存功能),反之不禁用 这个可以打开,我打开它后跑通了 | 是 |
Text to Send | 发送文本信息 | 是 |
Login User | 用户名-它不会使用默认实现 | 不是 |
Password | 密码-它不会使用默认实现,(N.B.【note well 注意】它在测试计划中采用非加密存储 ) | 不是 |
2.汇总/聚合报告
Label:每个JMeter的element的Name值,例如HTTP Request的Name;
样本:发出请求数量;模拟20个用户,循环100次,所以显示了2000;
平均值:平均响应时间(单位:ms);默认是单个Request的平均响应时间,当使用了Transaction Controller时,也可以以Transaction为单位显示平均响应时间;
中位数:50%的用户响应时间小于这个值;
95%百分位:95%的用户响应时间小于这个值;
99%百分位:99%的用户响应时间小于这个值;
最小值:用户响应时间最小值;
最大值:用户响应时间最大值;
异常%:测试出现的错误请求数量百分比;请求的错误率 = 错误请求的数量/请求的总数;若出现错误就要看服务端的日志查找定位原因;
吞吐量:Throughput简称TPS,吞吐量,默认情况下表示每秒处理的请求数,也就是指服务器处理能力,TPS越高说明服务器处理能力越好;
KB/sec:每秒从服务器端接收到的数据量。
本次实验配置
1.线程组配置
2.TCP取样器设置
实验结果展示
1.结果树
2.汇总报告
3.聚合报告
我的500个测试样本的平均响应时间为0ms,TPS值为503.5/sec(即每秒处理503个请求)。
我的电脑配置
我是win64,细致配置如下:
附录:JMeter压力并发测试教程
Jmeter压力并发测试完整,保姆级教程_jmeter并发测试-CSDN博客
JMeter压力测试/并发测试/性能测试入门教程 - 知乎 (zhihu.com)
补充:
WRK:有的人Linux环境并行使用的WRK,也取得了成功。