kafka监听topic消费_zabbix监控kafka消费

本文介绍了如何使用Zabbix监控Kafka的topic消费情况,包括查看Zookeeper和Kafka配置,获取group name和topic_name,修改Zabbix配置以允许root用户运行脚本,创建监控脚本并赋予相应权限,最后重启Zabbix并添加监控项。
摘要由CSDN通过智能技术生成

一、Kafka监控的几个指标

1、lag:多少消息没有消费 lag=logsize-offset2、logsize:Kafka存的消息总数

3、offset:已经消费的消息

Kafka管理工具 介绍:

二、查看zookeeper配置

cat /home/app/zookeeper/zookeeper/conf/zoo.cfg | egrep -v "^$|^#"

clientPort=2181

三、查看kafka配置

cat /home/app/kafka/kafka/config/server.properties | egrep -v "^$|^#"

port=9092

host.name=192.168.38.87

zookeeper.connect=192.168.38.87:2181,192.168.38.88:2181

四、查看kafka的group name

cd /home/app/zookeeper/zookeeper/bin

./zkCli.sh -server 192.168.38.87:2181

ls /consumers/

lijieGroup

quit

五、查看kafka的topic_name

/home/app/kafka/kafka/bin/kafka-run-class.sh kafka.tools.ConsumerOffsetChecker --group=lijieGroup --zookeeper=192.168.38.87:2181

六、修改zabbix配置文件

因为zabbix用户不能调用kafka的脚本,需要root用户启动zabbix_agent

vim /opt/zabbix/zabbix_agentd.conf

AllowRoot=1

User=root

Include=/opt/zabbix/zabbix_agentd.conf.d/

vim /opt/zabbix/zabbix_agentd.conf.d/kafka_status.conf

UserParameter=kafka.lag[*],/home/zabbix_scripts/kafka_mon.sh $1 $2 lag

UserParameter=kafka.offset[*],/home/zabbix_scripts/kafka_mon.sh $1 $2 offset

UserParameter=kafka.logsize[*],/home/zabbix_scripts/kafka_mon.sh $1 $2 logsize

chown -R zabbix:zabbix /opt/zabbix/zabbix_agentd.conf.d/kafka_status.conf

chmod -R 777 /opt/zabbix/zabbix_agentd.conf.d/kafka_status.conf

七、创建监控脚本

mkdir -pv /home/zabbix_scripts/

vim /home/zabbix_scripts/kafka_mon.sh

#!/bin/bash

kafka_ip="127.0.0.1"

kafka_port=2181

topic_name=$1

group_id=$2

pn=$3

/usr/local/kafka_2.11-0.11.0.0/bin/kafka-run-class.sh kafka.tools.ConsumerOffsetChecker --topic=$topic_name --group=$group_id --zookeeper=$kafka_ip:$kafka_port | grep -v Offset > /tmp/kafka-tp-${topic_name}-${group_id}.info

Offset=0

logSize=0

Lag=0

while read line

do

Offset=$((${Offset}+`echo $line |awk ‘{print $4}‘`))

logSize=$((${logSize}+`echo $line |awk ‘{print $5}‘`))

Lag=$(($Lag+`echo $line |awk ‘{print $6}‘`))

done < /tmp/kafka_topic_info.log

case $pn in

offset|Offset)

echo $Offset

;;

logsize|logSize)

echo $logSize

;;

lag|Lag)

echo $Lag

;;

*)

echo Error

;;

esac

八、给脚本和对应文件权限

chown -R zabbix:zabbix /home/zabbix_scripts/kafka_mon.sh

chmod -R 777 /home/zabbix_scripts/kafka_mon.sh

touch /tmp/kafka-tp-RouterOnOfflineStateChange-lijieGroup.info

chmod 777 /tmp/kafka-tp-RouterOnOfflineStateChange-lijieGroup.info

chown zabbix:zabbix /tmp/kafka-tp-RouterOnOfflineStateChange-lijieGroup.info

chmod 777  /home/app/kafka/kafka/bin/kafka-run-class.sh

九、重启zabbix

/etc/init.d/zabbix-agent restart

十、监控上增加3个键值

kafka.offset[RouterOnOfflineStateChange,lijieGroup]

kafka.logsize[RouterOnOfflineStateChange,lijieGroup]

kafka.lag[RouterOnOfflineStateChange,lijieGroup]

原文:https://www.cnblogs.com/lvcisco/p/10957357.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值