使用 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 的启动路径。