InfluxdbBackendListener扩展

作者: 测试随笔 | 来源:发表于2017-08-09 15:16 被阅读62次

        前几天文章介绍了测试结果环境监控基于influxdb、Grafana展示报表搭建。Jmeter错误日志信息写入结果文件,出现错误时第一时间查看比较吃力,基于后置处理器Backend Listener的InfluxdbBackendListenerClient简单扩展可实现错误日志Grafana实时展示。

InfluxdbBackendListenerClient

一、Influxdb数据格式

1、Influxdb insert

通过http端口

curl -i -XPOST 'http://127.0.0.1:8086/write?db=jmeter' --data-binary 'error,Tag=123,application=MIa\ APi Code="404",Label="HTTP请求" 1502245705524000000'

Line Protocol

influxdb写入数据,使用固定的Point格式,详情见influxdb官网文档

{measurement}{ ,tag_set} {field_set} {}timestamp}

error,Tag=123,application=MIa\ APi Code="404",Label="HTTP请求" 1502245705524000000

measurement :表名,如error

tag_set :tag标签,和时间戳共同确定唯一值

field_set:数据point

timestamp :时间戳

二、Jmeter Influxdb BackendListener插件

Jmeter基于CloseableHttpAsyncClient异步HTTP请求写入influxdb

1、HttpMetricsSender 请求发送

1.addMetric 

addMetric将influxdb Point数据写入metric list列表

addMetric

2.writeAndSendMetrics

writeAndSendMetrics异步NIO方式批量发送influxdb数据。数据发送失败不影响jmeter正常运行,超时时间及发送频率参考Jmeter配置文件。

2XX:成功,204成功但是内容为空

4XX:数据格式异常

5XX:服务端异常

writeAndSendMetrics

2、InfluxdbBackendListenerClient

handleSampleResults:处理sampler可以实现写入文件或者写入实例server

handleSampleResults

setupTest:客户端初始化操作,尽量避免进行测试行为。Executors、ScheduledExecutorService定时任务创建

setupTest

teardownTest:测试线程结束后,资源释放清理。定时任务关闭,influxdb资源释放

teardownTest

重点来了,Backend Listener的InfluxdbBackendListenerClient如何实现数据写入,addMetric等方法完成数据Metrics写入,基于ScheduledExecutorService接口通过run方法定时触发sendMetrics()实现。

addMetric sendMetrics

3、InfluxdbBackendListenerClient扩展

1、参考UserMetric,创建ErrorMetric定义错误Metric。只需要通过SampleResult获取错误相关内容即可。非必需类。

ErrorMetric

2、handleSampleResults获取SampleResult,写入ErrorMetric

ErrorMetric数据输入

3、addErrorCode按照influxdb Point格式组织influxdb数据并写入metric list列表

addErrorCode

备注:未考虑性能等问题,只介绍简单实现方式。后续可根据需要加入统计等等。

编写完成,运行Jmeter,数据成功写入influx后确认无误后,执行ant package 打包命令替换Jar即可。

select * from error   查看表是否自动创建数据写入

influxdb数据写入实例

三、Grafana展示

Grafana提供Table类型报表,可以使用此类型。设置Meterics时注意直接使用SQL语句,本人为配置成功,SQL语句方式可直接按照顺序展示。SQL语句也可以做错误统计,具体使用方式可访问官网自行查找使用方式。

ADD Panel Table Tab了 Edit

相关文章

  • InfluxdbBackendListener扩展

    前几天文章介绍了测试结果、环境监控基于influxdb、Grafana展示报表搭建。Jmeter错误日志信...

  • Swift 扩展

    扩展UIView 扩展String 扩展UIColor 扩展UIButton 扩展String 扩展UIImage...

  • ES6扩展

    字符串的扩展正则的扩展数值的扩展数组的扩展函数的扩展对象的扩展

  • ES6扩展

    字符串扩展 正则扩展 数值扩展 函数扩展 对象扩展 数组扩展 字符串扩展 模版字符串 部分新的方法 padStar...

  • Swift--扩展

    扩展的概念 扩展计算属性 扩展方法 扩展构造函数 扩展下标 扩展的概念 在Swift中可以使用一种扩展机制,在原有...

  • 从Java到Kotlin(六)

    扩展与委托 目录 1.扩展 1.1 扩展函数 1.2 扩展属性 1.3 扩展伴生对象 1.4 扩展的作用域 2.委...

  • ES6基础-ES6的扩展

    进行对字符串扩展,正则扩展,数值扩展,函数扩展,对象扩展,数组扩展。 开发环境准备: 编辑器(VS Code, A...

  • Vue项目开发与规范--es6语法规范篇

    目录 简介 let const 解构赋值 正则的扩展 字符串的扩展 数值的扩展 数组的扩展 函数的扩展 对象的扩展...

  • Kotlin-面向对象-进阶

    扩展 扩展方法 Kotlin支持扩展方法和扩展属性。语法:被扩展的类/接口名.方法名() 父类不能使用子类的扩展方...

  • 2021-03-14

    请求链接,稍后更新 扩展点简述 扩展点的生命周期及扩展点的执行时机 扩展点的作用 扩展点实战 更多Spring扩展...

网友评论

    本文标题:InfluxdbBackendListener扩展

    本文链接:https://www.haomeiwen.com/subject/ivdfrxtx.html