JMeter Logo

Jmeter 保存响应到文件

原创 2018年 10月 15日
标签: JMETER
本文发布至今已有6年零36天,可能不再适用,请谨慎对待。

先打个广告:欢迎关注我的公众号,参与 文史大挑战 趣味题目。使用方法见 这篇文章

公众号:晚花行乐

正文开始:

使用 Jmeter Non-GUI 模式下,遇到发生错误响应时,需要查看请求与响应的记录,然而默认是没有保存响应值的设置。同时即使 GUI 模式下,也需要保存响应值以查错或者留存档案。本文列举一些保存响应值到文件的方法。

本文使用的 Jmeter 是 4.0 版本

方法一: 修改默认属性

Jmeter 进入 Non-GUI 模式下的命令行是这样的:

$ jmeter -n -t [jmx file] -l [results file] -e -o [Path to web report folder]

其中的 -l 参数指定了输出结果文件 [results file] 的路径和文件名。而输出的 [results file] 的输出内容等各项指标,则由对应的 Jmeter 默认属性的规定。

Jmeter.properties

Jmeter 默认属性由Jmeter 目录下的 bin/jmeter.properties 文件指定,这里保存了许多影响 Jmeter 默认行为的属性值。搜索文件,可以找到如下所有和 results file 相关的属性,以下为节选:

#---------------------------------------------
# Results file configuration
#----------------------------------------------
...
#jmeter.save.saveservice.output_format=csv

# response_data is not currently supported for CSV output
#jmeter.save.saveservice.response_data=false
# Save ResponseData for failed samples
#jmeter.save.saveservice.response_data.on_error=false

从上面的几行文字可以看出:

  • 结果文件默认输出格式是 csv
  • 保存响应的功能并不支持 csv 格式, 只支持 xml
  • 可以设置保存的时机(on_error)

我们首先将上面两条属性修改为:

#---------------------------------------------
# Results file configuration
#----------------------------------------------
...
jmeter.save.saveservice.output_format=xml

# response_data is not currently supported for CSV output
jmeter.save.saveservice.response_data=true
# Save ResponseData for failed samples
#jmeter.save.saveservice.response_data.on_error=false

再用命令行格式

$ jmeter -n -t test.jmx -l results.jtl

重新以 Non-GUI 模式执行 Jmeter 用例。注意,因为这是输出结果文件格式已经改为 xml,不能再进一步解析为 Html 格式报告,所以这时 -e -o 参数无效。

得到的 results.jtl 可以使用 GUI 模式下的 View Results Tree 浏览打开观看,但是 View Results Tree 只能看到最多 200KB 的文件内容,更多的只能通过 grep 或者文本编辑器查看。

方法二: 用 Groovy 写入文件

使用 JSR223 PostProcessor 中的 Groovy 语言,可以灵活的读写文件。测试脚本配置如下:

Test Plan
  └─Thread Group1
     └─ HTTP Cookie Manager
         └─ Thread Group2

确认 JSR223 Post Processor 的语言类型选择的是 Groovy 后,在文本框中填入下列代码:

def resp = prev.getResponseData();
def filename = "/path/to/response.dat";

new File(filename).withOutputStream{ os ->
	for(int i=0; i< resp.length;i++){
		os.write(resp[i]);
	}
}

以上的代码就能将响应写入 filename 指定的文件中。文件名 filename 最好写成绝对路径,如果只写单个文件名,则保存的路径是 Jmeter 的启动路径。

如果您对本文有疑问或者寻求合作,欢迎 联系邮箱邮箱已到剪贴板

标签: JMETER
给个免费的赞吧~

精彩评论

本站 是个人网站,采用 署名协议 CC-BY-NC 授权。
欢迎转载,请保留原文链接 https://www.lfhacks.com/tech/jmeter-save-response-to-file/ ,且不得用于商业用途。