一、总体效果图

这里是将集群全部放在一起,可以根据自己的审美看怎么放

二、监控指标

其中有些指标与第一篇Zookeeper通过四字命令基础监控(Zabbix)的四字命令的指标是有重复的,二者选一个则可

三、实现

1、influxdb的安装

1)设置yum源

cat <<EOF | sudo tee /etc/yum.repos.d/influxdb.repo
[influxdb]
name = InfluxDB Repository - RHEL \$releasever
baseurl = https://repos.influxdata.com/rhel/\$releasever/\$basearch/stable
enabled =
gpgcheck =
gpgkey = https://repos.influxdata.com/influxdb.key
EOF

2)安装influxdb

yum install influxdb
systemctl start influxdb

3)修改配置文件(元数据以及数据存放目录)

[root@ip---- influxDB]# cat /etc/influxdb/influxdb.conf |grep "^\s*[^# \t].*$"
[meta]
dir = "/influxDB/meta"
[data]
dir = "/influxDB/data"
wal-dir = "/influxDB/wal"
series-id-set-cache-size =
[coordinator]
[retention]
[shard-precreation]
[monitor]
[http]
[logging]
[subscriber]
[[graphite]]
[[collectd]]
[[opentsdb]]
[[udp]]
[continuous_queries]
[tls]

4、数据目录授权

chown -R influxdb.influxdb /influxDB

5、重启influxdb

systemctl restart influxdb

6、创建zookeeper数据库,以及创建账号密码

CREATE USER "admin" WITH PASSWORD "admin" WITH ALL PRIVILEGES
create database zookeeper

2、zookeeper上打开JMX

1)vim ${Zookeeper-Home}/conf/zookeeper-env.sh
JMXLOCALONLY=false
JMXDISABLE=false
JMXPORT=
JMXAUTH=false
JMXSSL=false

2、重启Zookeeper

./zkServer.sh restart

3、JMXtrans的安装

1)安装配置jmxtrans

下载地址https://oss.sonatype.org/content/repositories/snapshots/org/jmxtrans/jmxtrans/ 这里有最新的版本,用老的版本有一些问题 ;JMXtrans可以随意安装在任何一台机器上,不是必须安装在Zookeeper机器上,只要JMXtrans与Zookeeper机器的网络及端口是通的就可以

wget https://oss.sonatype.org/content/repositories/snapshots/org/jmxtrans/jmxtrans/271-SNAPSHOT/jmxtrans-271-20190109.091025-10.rpm
yum -y install jmxtrans--20190109.091025-.rpm

2)它的目录文件

/var/lib/jmxtrans
/var/log/jmxtrans
/etc/rc.d/init.d/jmxtrans
/etc/jmxtrans
/usr/share/jmxtrans
/usr/share/jmxtrans/bin/jmxtrans
/usr/share/jmxtrans/lib/org/jmxtrans
/usr/share/jmxtrans/lib/org/jmxtrans/jmxtrans
/usr/bin/jmxtrans
/run/jmxtrans
/run/lock/subsys/jmxtrans

3)编辑zookeeper.json文件并放到/var/lib/jmxtrans/目录

一般我们的Zookeeper是一个集群,比如当我们的Zookeeper为3台的时候,则需要弄三份zookeeper.json文件,每一份对应Zookeeper集群的每一台机器,通过里面的host和port对应

{
"servers": [{
"port": ,
"host": "zookeeper-IP",
"alias": "zk",
"queries": [{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "org.apache.ZooKeeperService:name0=ReplicatedServer_id*",
"attr": ["QuorumSize"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "org.apache.ZooKeeperService:name0=ReplicatedServer_id*,name1=replica*,name2=*",
"attr": ["MaxClientCnxnsPerHost",
"MaxRequestLatency",
"AvgRequestLatency",
"MinRequestLatency",
"MaxSessionTimeout",
"MinSessionTimeout",
"OutstandingRequests",
"PacketsReceived",
"PacketsSent",
"PendingRevalidationCount",
"TickTime"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "org.apache.ZooKeeperService:name0=ReplicatedServer_id*,name1=replica*,name2=*,name3=InMemoryDataTree",
"attr": ["NodeCount",
"WatchCount"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "org.apache.ZooKeeperService:name0=ReplicatedServer_id*,name1=replica*,name2=*,name3=Connections,name4=*,name5=*",
"resultAlias": "Clients",
"attr": ["AvgLatency",
"LastLatency",
"MaxLatency",
"MinLatency",
"OutstandingRequests",
"PacketsReceived",
"PacketsSent"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "org.apache.ZooKeeperService:name0=StandaloneServer_port*",
"resultAlias": "Clients",
"attr": ["AvgLatency",
"LastLatency",
"MaxLatency",
"MinLatency",
"OutstandingRequests",
"PacketsReceived",
"PacketsSent",
"NumAliveConnections"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "java.lang:type=Memory",
"resultAlias": "Memory",
"attr": ["HeapMemoryUsage",
"NonHeapMemoryUsage"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "java.lang:type=OperatingSystem",
"resultAlias": "Process",
"attr": ["OpenFileDescriptorCount",
"ProcessCpuLoad"]
},
{
"outputWriters": [{
"@class": "com.googlecode.jmxtrans.model.output.InfluxDbWriterFactory",
"url": "http://localhost:8086/",
"database": "zookeeper",
"username": "admin",
"password": "admin"
}],
"obj": "java.lang:type=Threading",
"resultAlias": "Threading",
"attr": ["ThreadCount"]
}],
"numQueryThreads":
}]
}

4)启动JMXtrans

启动后,查看日志/var/log/jmxtrans/jmxtrans.log,看是否启动成功,若有错误则根据对应的错误解决就可以

/usr/share/jmxtrans/bin/jmxtrans start

4、Grafna上配置数据源

当创建Query,选择Influxdb数据源后,若有对应的指标出来,表明是OK的

JMXtrans + InfluxDB + Grafana实现Zookeeper性能指标监控的更多相关文章

  1. 基于jmxtrans+influxdb+grafana实现对canal监控

    最近在调研canal数据同步系统的监控方案,网上关于jmxtrans+influxdb+grafana监控kafka的文档很多,没有监控canal的.通过几天的摸索,大致明白了来龙去脉.监控流程基本是 ...

  2. Kafka使用jmxtrans+influxdb+grafana监控JMX指标

    最近在搞Kafka集群监控,之前也是看了网上的很多资料.之所以使用jmxtrans+influxdb+grafana是因为界面酷炫,可以定制化,缺点是不能操作Kafka集群,可能需要配合Kafka M ...

  3. Telegraf+InfluxDB+Grafana快速搭建实时监控系统 监控postgresql

    Telegraf+InfluxDB+Grafana快速搭建实时监控系统  监控postgresql

  4. 使用 Metrics.net + influxdb + grafana 搭建项目自动化监控和预警方案

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/qq_25042791/article/d ...

  5. 搭建jmeter+influxdb+grafana压测实时监控平台(超详细,小白适用)

    1.前言 在使用jmeter做性能测试的时候,监控系统性能的时候,无论是使用插件还是报告生成,都没法实现实时监控.使用JMeter+Influxdb+Grafana可以实现实时监控. 本次环境搭建各软 ...

  6. 基于telegraf+influxdb+grafana进行postgresql数据库监控

    前言 随着公司postgresql数据库被广泛应用,尤其是最近多个项目在做性能测试的时候都是基于postgresql的数据库,为了确定性能瓶颈是否会出现在数据库中,数据库监控也被我推上了日程.在网上找 ...

  7. .NET Core微服务之基于App.Metrics+InfluxDB+Grafana实现统一性能监控

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.关于App.Metrics+InfluxDB+Grafana 1.1 App.Metrics App.Metrics是一款开源的支持. ...

  8. 基于InfluxDB+Grafana打造大数据监控利器--转

    这是一个大数据爆发的时代.面对信息的激流.多元化数据的涌现,我们在获取.存储.传输.理解.分析.应用.维护大数据时,无疑需要一种便捷的信息交流通道,以便快速.有效.准确地理解和驾驭这个过程.本文将通过 ...

  9. Telegraf+Influxdb+Grafana自动化运维监控

    概述:Telegraf收集信息,influxdb时序数据库存储数据,grafana平台展示数据,并进行监控告警,组成一个自动化运维监控平台. 一.influxdb ​ InfluxDB是一个由Infl ...

随机推荐

  1. FreeSql (七)插入数据时忽略列

    var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;" + "Initia ...

  2. 实现一个extend函数

    NOW,今天让我们来实现一个extend函数. 具体思路: 使用Object.defineProperty()对属性的特性进行设置,然后通过Object.getOwnPropertyDescripto ...

  3. TestNG(九) 异常测试

    package com.course.testng.suite; import org.testng.annotations.Test; public class ExpectedExeption { ...

  4. SpringBoot——Web开发(静态资源映射)

    静态资源映射 SpringBoot对于SpringMVC的自动化配置都在WebMVCAutoConfiguration类中. 其中一个静态内部类WebMvcAutoConfigurationAdapt ...

  5. c++异常处理函数

    注意: throw 抛出异常,catch 捕获异常,try 尝试捕获异常 catch 中的参数类型要和throw 抛出的数据类型一致 try{    //可能抛出异常的语句}catch (异常类型1) ...

  6. java.lang.IllegalArgumentException: System memory 259522560 must be at least 471859200.

    报错信息 java.lang.IllegalArgumentException: System memory 259522560 must be at least 471859200. Please ...

  7. jupyter编辑快捷键

    Jupyter笔记本有两种不同的键盘输入模式. 编辑模式允许您将代码或文本输入到一个单元格中,并通过一个绿色的单元格来表示 命令模式将键盘与笔记本级命令绑定在一起,并通过一个灰色的单元格边界显示,该边 ...

  8. 主动降噪技术(ANC)的前生今世--原理仿真

    一 原理: 主动降噪就是通过反相检测麦克风的声音或噪声来减弱周围环境的噪声让扬声器出来的声音听起来更清晰.主动降噪技术的目标就是通过一个自适应滤波器把不想要的噪声反相从而把噪声约束到固定的范围内.该系 ...

  9. Flume和Kafka完成实时数据的采集

    Flume和Kafka完成实时数据的采集 写在前面 Flume和Kafka在生产环境中,一般都是结合起来使用的.可以使用它们两者结合起来收集实时产生日志信息,这一点是很重要的.如果,你不了解flume ...

  10. Hadoop点滴-HDFS命令行接口

    1.-help[cmd] 显示命令的帮助信息 ./hdfs dfs -help ls1 2.-ls(r) 显示当前目录下的所有文件 -R层层循出文件夹 ./hdfs dfs -ls /log/map ...