这是今年1月24日的旧文,发现没在这里发过,就搬运过来了。

声明

  1. 本文讨论的使用场景主要为使用已有的 jmx 脚本,并配合 json 对 jmx 脚本进行部分参数的动态修改
  2. 只补充一些官方文档上没有提到的使用注意事项,所以官网上阐述得比较清楚的点,文章里就不再赘述。

什么是 bzt?

bzt,全名是Blazemeter taurus,是Blazemeter旗下的一款开源组件,官方宣称此组件的底层依赖于JMeterGatlingLocust.ioSelenium WebDriver,并且经过了自动化程度高、可操作性好的封装,使得性能测试与功能测试的过程变得更加简单。

使用 bzt 压测的基本流程

使用 bzt 中的jmeter引擎压测,有两种方式:

  1. 直接运行已有的 jmx 文件
    bzt example.jmx
  2. 利用yaml或者json生成一个 jmx 脚本并运行
    bzt example.yaml / bzt example.json

可以发现,其实jmeter里运行的始终是 jmx 文件,只不过 bzt 对 jmx 文件做了一层包装,使得没有接触过 jmeter 的用户也可以根据官方文档的指引用yaml/json生成较为简单的 jmx 脚本。

编写脚本的注意事项

本文主要讨论的使用场景来源于我们所开发的 TCPS 平台——用户上传自己的 jmx 脚本,而用户每次运行脚本时都可能会修改这几个值:①需要压测的线程、②并发数和③压测时长;另外在运行脚本前,用户还需要调试脚本,并得到请求的 response 数据。

1. 如何修改已有脚本的某项参数值

通过 bzt 所提供的set-prop参数,可以动态修改已有脚本的某些参数值,如图:



但是官方文档中没有提到的事情有:

  1. 只能通过节点的 testname 识别到该节点。
  2. 当有多个节点的 testname 相同时,会修改所有拥有相同 testname 的节点的值
  3. 没有办法识别 jmx 的层级,如果需要区分两个不同层级的节点,建议修改 testname

2. 如何选择性地执行已有脚本的线程组?

图中的红框部分就是启用部分线程组,禁用另一部分线程组,以达到动态选择线程组去执行的目的。



语法格式很好明白,但是有那么几点注意事项:

  1. 通过 ThreadGroup 的 testname 去识别线程组,并且把该 ThreadGroup 节点的enable值设置为true 或者 false,如图:

  2. 在设置enable的线程组数组时,如果脚本里有多个 testname 相同的线程组,有以下几种情况:

    (1)这几个线程组节点的 enable 值都为false;bzt 不会运行任何一个线程组

    (2)这几个线程组节点的 enable 值有些为false,有些为true;bzt 只会运行enable值为true的线程组

    (3)这几个线程组节点的 enable 值都为true;bzt 会运行全部线程组

  3. 在设置disable的线程组数组时,不管线程组原本的enable值为true或者false,都会被设置为false

3. 如何查看具体的测试结果?

bzt 提供两种查看结果的方式,分别是xml格式和csv格式。

查看xml结果

如果想得到xml格式的结果,具体的脚本设置如下:

{
"execution": [
{
"write-xml-jtl": "error",
"scenario": "example"
}
],
"scenarios": {
"example": {
"script": "example.jmx"
}
},
"modules": {
"jmeter": {
"xml-jtl-flags": {
"xml":`true`,
"fieldNames":`true`,
"time":`true`,
"timestamp":`true`,
"latency":`true`,
"connectTime":`true`,
"success":`true`,
"label":`true`,
"code":`true`,
"message":`true`,
"threadName":`true`,
"dataType":`true`,
"encoding":`true`,
"assertions":`true`,
"subresults":`true`,
"responseData":`false`,
"samplerData":`false`,
"responseHeaders":`true`,
"requestHeaders":`true`,
"responseDataOnError":`true`,
"saveAssertionResultsFailureMessage":`true`,
"bytes":`true`,
"threadCounts":`true`,
"url":`true`
}
}
}
}

其中write-xml-jtl的值有error(默认值) 、fullnone三种,以下依次介绍三种情况。

  1. write-xml-jtl的值为error

    设置完成并运行后,会从项目文件夹里得到error.jtlkpi.jtl两个结果文件,如图



    查看这两个文件,里面的内容分别是这是因为我测试的两个接口都返回了404,而write-xml-jtl的值为error则表示把错误日志以xml格式输出。

  2. write-xml-jtl的值为full

    运行后,会从项目文件夹里得到trace.jtlkpi.jtl两个结果文件,如图

    查看这两个文件的内容,会得到



    因为我们把write-xml-jtl的值设置为full,那么 bzt 就把所有的日志都以xml格式打印在了 trace.jtl这个文件里了。

  3. write-xml-jtl的值为none

    运行后,项目文件夹里只有kpi.jtl这个结果文件,如图

    查看这个文件的内容,如图

    这意味着如果我们把write-xml-jtl的值设置为none,它不会打印任何值,项目里只有默认生成的结果文件。

查看csv结果

如果想得到csv格式的结果,脚本设置如下:

{
"modules": {
"jmeter": {
"csv-jtl-flags": {
"xml": false,
"fieldNames": true,
"time": true,
"timestamp": true,
"latency": true,
"connectTime": true,
"success": true,
"label": true,
"code": true,
"message": true,
"threadName": true,
"dataType": false,
"encoding": false,
"assertions": false,
"subresults": false,
"responseData": false,
"samplerData": false,
"responseHeaders": false,
"requestHeaders": false,
"responseDataOnError": false,
"saveAssertionResultsFailureMessage": false,
"bytes": true,
"hostname": true,
"threadCounts": true,
"url": false
}
}
}
}

用同样的接口测试后,会得到一个kpi.jtl文件,如图

查看文件,可以看到刚才设置的值都被打印出来了,如图

如果把所有的属性值都设置成true,那么会得到下面这个文件

注意事项

无论是使用xml还是csv,有两点需要注意

  1. 当使用csv-jtl-flags的时候,xml属性必须为false,不然会得到Error: Could not determine delimiter报错,如图

  2. 当使用xml-jtl-flags的时候,如果xml属性为false,bzt 不会报错,但是生成的所有结果文件都会是csv格式,如图

    (1)只打印错误信息

    (2)打印所有信息

编写 bzt 脚本的正确姿势的更多相关文章

  1. (转)Git 提交的正确姿势:Commit message 编写指南

    Git 每次提交代码,都要写 Commit message(提交说明),否则就不允许提交. $ git commit -m "hello world" 上面代码的-m参数,就是用来 ...

  2. Git 提交的正确姿势

    Git 提交的正确姿势:Commit message 编写指南 SCOP范围 middleware core config plugin test type范围 Git 每次提交代码,都要写 Comm ...

  3. 解锁redis锁的正确姿势

    解锁redis锁的正确姿势 redis是php的好朋友,在php写业务过程中,有时候会使用到锁的概念,同时只能有一个人可以操作某个行为.这个时候我们就要用到锁.锁的方式有好几种,php不能在内存中用锁 ...

  4. Redis实现分布式锁的正确姿势

    分布式锁一般有三种实现方式:1. 数据库乐观锁:2. 基于Redis的分布式锁:3. 基于ZooKeeper的分布式锁.本篇博客将介绍第二种方式,基于Redis实现分布式锁.虽然网上已经有各种介绍Re ...

  5. 开发函数计算的正确姿势 —— 使用 Fun Local 本地运行与调试

    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数计算 ...

  6. 【分布式缓存系列】Redis实现分布式锁的正确姿势

    一.前言 在我们日常工作中,除了Spring和Mybatis外,用到最多无外乎分布式缓存框架——Redis.但是很多工作很多年的朋友对Redis还处于一个最基础的使用和认识.所以我就像把自己对分布式缓 ...

  7. Taro 多端开发的正确姿势:打造三端统一的网易严选(小程序、H5、React Native)

    笔者所在的趣店 FED 早在去年 10 月份就已全面使用 Taro 框架开发小程序(当时版本为 1.1.0-beta.4),至今也上线了 2 个微信小程序.2 个支付宝小程序. 之所以选用 Taro, ...

  8. linux 的基本操作(编写shell 脚本)

    终于到shell 脚本这章了,在以前笔者卖了好多关子说shell脚本怎么怎么重要,确实shell脚本在linux系统管理员的运维工作中非常非常重要.下面笔者就带你正式进入shell脚本的世界吧. 到现 ...

  9. 编写Shell脚本的最佳实践

    编写Shell脚本的最佳实践 http://kb.cnblogs.com/page/574767/ 需要记住的 代码有注释 #!/bin/bash # Written by steven # Name ...

随机推荐

  1. 016(剪花布条)(KMP)

    题目:http://ybt.ssoier.cn:8088/problem_show.php?pid=1465 题目思路:KMP模板题,该说的都在代码里 #include<bits/stdc++. ...

  2. springboot中的任务处理

    springboot中的任务处理 一.异步任务 在开发中有时用户提交的数据,后台需要一定时间才能做出响应,此时用户在前台也不能在等待中,此时就应该先开启异步请求处理,利用多线程,先给前台反馈,后台另一 ...

  3. 未找到与名为“xxx”的控制器匹配的类型。

    自己封装了一个BaseApiControllerr把他独立成一个项目出来在引用不行,而用默认自带的ApiControllerr可以. <Error> <Message> 未找到 ...

  4. Tomcat介绍和配置使用

    目录 JavaWeb 的概念 什么是 JavaWeb? 什么是请求? 什么是响应? 请求和响应的关系 Web 资源的分类 常用的 Web 服务器 Tomcat 服务器和 Servlet 版本的对应关系 ...

  5. CF1703A YES or YES? 题解

    题意:输入一个长度为 \(3\) 的字符串,判断其是否为 \(YES\),忽略大小写. 做法:输入字符串,直接判断. #include<cstdio> #include<iostre ...

  6. vue使用vuex报错 "export 'watch' was not found in 'vue'

    问题 安装Vuex后报错"export 'watch' was not found in 'vue' 解决方法 如果你的vue版本是 2.X ,将vuex升到 3.X.X 就能够解决 npm ...

  7. 微信公众号授权登录后报redirect_uri参数错误的问题

      在进行微信公众号二次开发的时候,需要通过授权码模式来进行微信授权.比如,在进行登录的时候,用户点击了登录按钮,然后弹出一个授权框,用户点击同意后,就可以获取用户的OpenId等信息了.这篇文章主要 ...

  8. ROS机械臂 Movelt 学习笔记4 | Move Group 接口 Python

    Python 的使用总是比 C++ 简单许多,Move Group 的 Python 接口更为便捷,也为使用者提供了很多用于操纵机器人和机械臂的函数,能够和 C++ 接口实现相同的功能: 设置机械臂的 ...

  9. Spherical类定义和实现

    此类是一个全景摄像机视角,书上介绍了详细原理.直接给实现代码. 类声明: #pragma once #ifndef __SPHERICAL_HEADER__ #define __SPHERICAL_H ...

  10. 集成 Spring Doc 接口文档和 knife4j-SpringBoot 2.7.2 实战基础

    优雅哥 SpringBoot 2.7.2 实战基础 - 04 -集成 Spring Doc 接口文档和 knife4j 前面已经集成 MyBatis Plus.Druid 数据源,开发了 5 个接口. ...