高效利用 jmeter 性能测试数据写入文件

本贴最后更新于 918 天前,其中的信息可能已经事过景迁

使用过jmeter的同学,应该都会使用监听器,在每个监听器中,都会有一个“所有数据写入一个文件”的功能,那这个功能应该怎么用呢?今天,我们就来讲讲这个功能的使用。

save20211012151506.png

几乎所有的监听器都有这样一个功能。

哪对于这个监听器都带有的功能,到底该怎么用呢?

点击“浏览”按钮,会弹出系统的文件选择窗口

jtl20211013193923.png

我们可以从弹窗的文件类型中看到,支持的文件类型有三种:xml、jtl、csv。

其实,jmeter还支持一种:.db 只是,这种类型很少被用了。

也就是说,我们选择写入的文件类型有三种选择。期中,csv是jmeter目前版本默认的。可以在jmeter.properties文件中,找到“jmeter.save.saveservice.output_format=”参数的值。

自己选择一个路径,可以选择一个已经存在的文件,也可以自己创建一个空文件,不过,建议使用空文件,因为,在jmeter默认参数配置时,"resultcollector.action_if_file_exists=ASK",如果文件已经存在,就会弹窗提示.

save20211014142659.png

当然,也可以自己修改为“APPEND” 自动追加到文件末尾、“DELETE”自动删除原文件再创建新文件。

默认情况下,csv文件,保存的字段有 (jtl文件也相同)

timeStamp   elapsed label   responseCode    responseMessage threadName  dataType    success failureMessage  bytes   sentBytes   grpThreads  allThreads  URL Latency IdleTime    Connect
字段 信息
timeStamp 时间戳 如:1634187509448
elapsed 耗时,单位:ms毫秒
label 取样器名称 如:HTTP request
responseCode 响应代码 如:200
responseMessage 响应消息 如:OK
threadName 线程名称 如:线程组 1-1
dataType 数据类型 如: text
success 成功与否 如:true
failureMessage 失败消息
bytes 样本中的字节数
sentBytes 发送样本的字节数
grpThreads 此线程组中的活跃线程数
allThreads 所有线程组中的活跃线程数
URL 取样器请求地址
Latency 延迟耗时
IdleTime 空闲 时间 单位: ms毫秒
Connect 建立连接的时间

细心的同学,应该从这个图表中可以发现,这个csv中是没有request-body和response-body的,也就是说,请求和响应的一些数据是没有写入文件的。这些数据,主要是在做性能分析生成图表的时候使用的。

哪到底怎么用呢?

save20211014174713.png

或者使用“聚合报告” 元件:

save20211014174820.png

就能看到运行的结果,以及统计分析报告。

这个用法是不是很简单,你 ‘学废了’ 吗?

但是,因为他是csv文件或jtl文件,还是有一些不足的。首先,csv文件,是不会保存请求体和响应结果相关的数据,所以,在使用“查看结果树” 元件来查看时,request body, request headers,response body, response headers 中都是没有数据的。然后,就是,如果csv文件或jtl文件有大几十M或几百M,在使用“查看结果树” 元件查看时,可能会导致jmeter无响应。

在jmeter5.1.1版本开始,如果你使用的图形界面,你也可以把csv文件或jtl文件,生成html报告。

save20211014184454.png

点击第1个“浏览”,选择csv文件或jtl文件,点击第2个“浏览” ,选择jmeterbin文件夹中的jmeter.properties或user.properties文件,点击第3个“浏览”, 选择一个空文件夹,然后点击最底部的 “Gererate report” 按钮,就可以生成html到你选择的空文件夹中。

save20211014185011.png

默认的csv或jtl文件,没有保存请求体和响应相关数据,那有没有什么办法解决呢?

save20211014185939.png

这样,请求体和响应相关数据,就都保存到了 xml文件中。

注意:

1、想要保存请求体和响应相关数据,文件必须为xml格式,必须构想Save As XML

2、Save Sampler Data(XML)会保存请求的cookie、请求方法、请求体

save20211014191555.png

用这两种方法生成的xml文件,就都包含了请求体和响应相关数据,在jmeter图形界面中,选择”查看结果树“,点击选择写入文件的浏览,打开xml文件,这个时候,我们查看到请求 和 响应的详细信息。

save20211014192059.png

注意:

xml文件不能像csv、jtl文件一样生成html报告,它要生成报告,需要与ant集成。

前面,我们都是讲的在jmeter图形界面中,把数据写入文件,我们也可以通过采用无图形界面的CLI命令来生成csv或jtl文件。

jmeter -n -t xx.jmx -l xxx.jtl -e -o xxxxempty_dict

xx.jmx是jmeter脚本,xxx.jtl或xxx.csv是生成的文件,xxxxempty_dict是结果转换为的html文件。

好了,对于jmeter生成文件,你学会了吗?

回帖
请输入回帖内容 ...