JMeter+InfluxDB+Grafana性能监控

本文详细介绍了如何配置InfluxDB,启动服务,以及编写JMeter测试计划来发送数据到InfluxDB。然后在Grafana中设置数据源,解析JMeter的性能数据,并通过自定义监控参数和使用开源Dashboard模板实现性能监控的可视化。重点关注了Backend Listener的配置,包括summaryOnly和useRegexpForSamplersList的设置,以及如何根据需求过滤请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

InfluxDB配置

influxDB配置文件

influxDB配置文件默认保存在/etc/influxdb/influxdb.conf

可以通过influxd config命令,查看influxd的配置

Jmeter使用graphite协议去写入数据到InfluxDB,因此,需要在InfluxDB配置文件启用它,如下:

[[graphite]]
  enabled = true
  bind-address = ":2003"
  database = "jmeter"
  retention-policy = ""
  protocol = "tcp"
  batch-size = 5000
  batch-pending = 10
  batch-timeout = "1s"
  consistency-level = "one"
  separator = "."
  udp-read-buffer = 0
influxDB启动

使用以下-config选项将进程指向正确的配置文件:

influxd -config /etc/influxdb/influxdb.conf

influxDB常用语句
[root@zuozewei ~]# influx  #登录数据库
> CREATE DATABASE "jmeter" #创建数据库
> show databases;
name: databases
name
----
_internal
jmeter
testdb
> use testdb;  #切换数据库
> show  measurements;
> 
> drop measurement tables_name  #删除表
> SELECT mean("value") FROM "load" where time < now() - 15s GROUP BY time(15s) fill(null); # 常用查询
> CREATE USER "admin" WITH PASSWORD 'admin' WITH ALL PRIVILEGES # 创建管理员权限的用户

JMeter配置

  1. 创建一个测试计划,并添加Backend Listener
  2. 设置InfluxDB IP及端口设置InfluxDB IP及端口
  3. 运行测试,等待几秒运行测试,等待几秒
  4. 查看JMeter是否生成错误日志查看JMeter是否生成错误日志

JMeter配置如下:
在这里插入图片描述
以上的配置,跟默认情况不一样的是,将summaryOnly设为false,useRegexpForSamplersList设为true,并配置了samplersList的正则表达试为.*,目的是可以监听所有的Request请求。

如果想做请求过滤,例如配置了samplersList的正则表达试为JDBC.*,就可以监听所有以JDBC名称开头的Request请求。

Grafana中配置InfluxDB的数据源

Grafana中InfluxDB的配置如下:
在这里插入图片描述
在这里插入图片描述

JMeter中InfluxDB含义

线程数/用户相关指标

test.minAT-Min active threads:最小活跃线程数
test.maxAT-Max active threads:最大活跃线程数
test.meanAT-Mean active threads:活跃线程数
test.startedT-Started threads:启动线程数
test.endedT-Finished threads:结束线程数

响应时间指标

.ok.count:采样器的成功响应数
.h.count:每秒点击数
.ok.min:采样器成功最短响应时间
.ok.max:采样器成功最长响应时间
.ok.avg:采样器成功平均响应时间
.ok.pct:采样器成功响应百分比
.ko.count:采样器失败响应数
.ko.min:采样器失败的响应最短时间
.ko.max:采样称失败最长响应时间
.ko.avg:采样器失败平均响应时间
.ko.pct:采样器失败响应百分比
.a.count:采样器响应数(ok.count和ko.count的总和)
.a.min:采样器最小响应时间(ok.count和ko.count的最小值)
.a.max:采样器最大响应时间(ok.count和ko.count的最大值)
.a.avg:采样器平均响应时间(ok.count和ko.count的平均值)
.a.pct:采样器响应百分比(根据和失败样本的总数计算)

Backend Listener的默认百分位设置为“90;95;99”,即百分位数为90%,95%和99%。
Graphite使用点(“.”)去拆分的元素,这可能与十进制百分位值混淆。JMeter转换任何此类值,用下划线(“ - ”)替换点(“.”)。例如,“99.9 ”变为“99_9 ”
默认情况下,JMeter发送在samplerName“all”下累计的所有采样器的指标。 如果配置了 BackendListenerSamplersList,那么JMeter还会发送匹配样本名称的指标,前提是配置 summaryOnly=true

自定义监控参数

在查询条件中,选择你要监控的指标,可以添选多个指标,配置完成后,展示效果如下:
在这里插入图片描述
常用的监控指标:

名称描述
jmeter.all.h.count所有请求的TPS
jmeter.<请求名称>.h.count对应<请求名称>的TPS
jmeter.all.ok.pct9999%的请求响应时间
jmeter.<请求名称>.ok.pct99对应<请求名称>99%的请求响应时间
jmeter.all.test.startedT线程数
采用开源的Dashboard模版

可以去对应Dashboard模版官网查找对应的Dashboard,导入到Grafana中
在这里插入图片描述

JMeter Load Test的jar包

在这里插入图片描述

Backend Listener配置

在这里插入图片描述

Grafana监控效果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值