分享好友 最新动态首页 最新动态分类 切换频道
选它准没错,Kafka可视化监控之Eagle
2024-12-29 19:50

Kafka-Eagle框架可以监控Kafka集群的整体运行情况,在生产环境中经常使用。

一、MySQL环境准备

Kafka-Eagle的安装依赖于MySQL,MySQL主要用来存储可视化展示的数据。如果集群中之前安装过MySQL可以跨过该步。

二、Kafka环境准备

关闭Kafka集群

[bigdata@hadoop102 kafka]$ kf.sh stop

在/home/bigdata/bin目录下kf.sh脚本文件如下

#! /bin/bash

case $1 in

"start"){

for i in hadoop102 hadoop103 hadoop104

do

echo " --------启动 $i Kafka-------"

ssh $i "/opt/module/kafka_2.12-3.0.0/bin/kafka-server-start.sh -daemon /opt/module/kafka_2.12-3.0.0/config/server.properties"

done

};;

"stop"){

for i in hadoop102 hadoop103 hadoop104

do

echo " --------停止 $i Kafka-------"

ssh $i "/opt/module/kafka_2.12-3.0.0/bin/kafka-server-stop.sh "

done

};;

esac

修改/opt/module/kafka/bin/kafka-server-start.sh

[bigdata@hadoop102 kafka]$ vim bin/kafka-server-start.sh

修改如下参数值

if [ "x$KAFKA_HEAP_OPTS" = "x" ]; then

export KAFKA_HEAP_OPTS="-Xmx1G -Xms1G"

fi

if [ "x$KAFKA_HEAP_OPTS" = "x" ]; then

export KAFKA_HEAP_OPTS="-server -Xms2G -Xmx2G -XX:PermSize=128m -XX:+UseG1GC -XX:MaxGCPauseMillis=200 -XX:ParallelGCThreads=8 -XX:ConcGCThreads=5 -XX:InitiatingHeapOccupancyPercent=70"

export JMX_PORT="9999"

#export KAFKA_HEAP_OPTS="-Xmx1G -Xms1G"

fi

注意:修改之后在启动Kafka之前要分发到其他节点。

[bigdata@hadoop102 bin]$ xsync kafka-server-start.sh

在/home/bigdata/bin目录下xsync文件代码如下

#!/bin/bash

#1. 判断参数个数

if [ $# -lt 1 ]

then

echo Not Enough Arguement!

exit;

fi

#2. 遍历集群所有机器

for host in hadoop102 hadoop103 hadoop104

do

echo ==================== $host ====================

#3. 遍历所有目录,挨个发送

for file in $@

do

#4. 判断文件是否存在

if [ -e $file ]

then

#5. 获取父目录

pdir=$(cd -P $(dirname $file); pwd)

#6. 获取当前文件的名称

fname=$(basename $file)

ssh $host "mkdir -p $pdir"

rsync -av $pdir/$fname $host:$pdir

else

echo $file does not exists!

fi

done

done

三、Kafka-Eagle安装

官网:https://www.kafka-eagle.org/

上传压缩包kafka-eagle-bin-2.0.8.tar.gz到集群 /opt/software目录

解压到本地

[bigdata@hadoop102 software]$ tar -zxvf kafka-eagle-bin-2.0.8.tar.gz

进入刚才解压的目录

[bigdata@hadoop102 kafka-eagle-bin-2.0.8]$ ll

总用量 79164

-rw-rw-r--. 1 bigdata bigdata 81062577 10月 13 00:00 efak-web-2.0.8-bin.tar.gz

将efak-web-2.0.8-bin.tar.gz解压至/opt/module

[bigdata@hadoop102 kafka-eagle-bin-2.0.8]$ tar -zxvf efak-web-2.0.8-bin.tar.gz -C /opt/module/

修改名称

[bigdata@hadoop102 module]$ mv efak-web-2.0.8/ efak

修改配置文件 /opt/module/efak/conf/system-config.properties

[bigdata@hadoop102 conf]$ vim system-config.properties

######################################

# multi zookeeper & kafka cluster list

# Settings prefixed with 'kafka.eagle.' will be deprecated, use 'efak.' instead

######################################

efak.zk.cluster.alias=cluster1

cluster1.zk.list=hadoop102:2181,hadoop103:2181,hadoop104:2181/kafka

######################################

# zookeeper enable acl

######################################

cluster1.zk.acl.enable=false

cluster1.zk.acl.schema=digest

cluster1.zk.acl.username=test

cluster1.zk.acl.password=test123

######################################

# broker size online list

######################################

cluster1.efak.broker.size=20

######################################

# zk client thread limit

######################################

kafka.zk.limit.size=32

######################################

# EFAK webui port

######################################

efak.webui.port=8048

######################################

# kafka jmx acl and ssl authenticate

######################################

cluster1.efak.jmx.acl=false

cluster1.efak.jmx.user=keadmin

cluster1.efak.jmx.password=keadmin123

cluster1.efak.jmx.ssl=false

cluster1.efak.jmx.truststore.location=/data/ssl/certificates/kafka.truststore

cluster1.efak.jmx.truststore.password=ke123456

######################################

# kafka offset storage

######################################

# offset保存在kafka

cluster1.efak.offset.storage=kafka

######################################

# kafka jmx uri

######################################

cluster1.efak.jmx.uri=service:jmx:rmi:///jndi/rmi://%s/jmxrmi

######################################

# kafka metrics, 15 days by default

######################################

efak.metrics.charts=true

efak.metrics.retain=15

######################################

# kafka sql topic records max

######################################

efak.sql.topic.records.max=5000

efak.sql.topic.preview.records.max=10

######################################

# delete kafka topic token

######################################

efak.topic.token=keadmin

######################################

# kafka sasl authenticate

######################################

cluster1.efak.sasl.enable=false

cluster1.efak.sasl.protocol=SASL_PLAINTEXT

cluster1.efak.sasl.mechanism=SCRAM-SHA-256

cluster1.efak.sasl.jaas.config=org.apache.kafka.common.security.scram.ScramLoginModule required username="kafka" password="kafka-eagle";

cluster1.efak.sasl.client.id=

cluster1.efak.blacklist.topics=

cluster1.efak.sasl.cgroup.enable=false

cluster1.efak.sasl.cgroup.topics=

cluster2.efak.sasl.enable=false

cluster2.efak.sasl.protocol=SASL_PLAINTEXT

cluster2.efak.sasl.mechanism=PLAIN

cluster2.efak.sasl.jaas.config=org.apache.kafka.common.security.plain.PlainLoginModule required username="kafka" password="kafka-eagle";

cluster2.efak.sasl.client.id=

cluster2.efak.blacklist.topics=

cluster2.efak.sasl.cgroup.enable=false

cluster2.efak.sasl.cgroup.topics=

######################################

# kafka ssl authenticate

######################################

cluster3.efak.ssl.enable=false

cluster3.efak.ssl.protocol=SSL

cluster3.efak.ssl.truststore.location=

cluster3.efak.ssl.truststore.password=

cluster3.efak.ssl.keystore.location=

cluster3.efak.ssl.keystore.password=

cluster3.efak.ssl.key.password=

cluster3.efak.ssl.endpoint.identification.algorithm=https

cluster3.efak.blacklist.topics=

cluster3.efak.ssl.cgroup.enable=false

cluster3.efak.ssl.cgroup.topics=

######################################

# kafka sqlite jdbc driver address

######################################

# 配置mysql连接

efak.driver=com.mysql.jdbc.Driver

efak.url=jdbc:mysql://hadoop102:3306/ke?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull

efak.username=root

efak.password=root

######################################

# kafka mysql jdbc driver address

######################################

#efak.driver=com.mysql.cj.jdbc.Driver

#efak.url=jdbc:mysql://127.0.0.1:3306/ke?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull

#efak.username=root

#efak.password=123456

添加环境变量

[bigdata@hadoop102 conf]$ sudo vim /etc/profile.d/my_env.sh

# kafkaEFAK

export KE_HOME=/opt/module/efak

export PATH=$PATH:$KE_HOME/bin

注意:source /etc/profile

[bigdata@hadoop102 conf]$ source /etc/profile

启动

注意:启动之前需要先启动ZK以及KAFKA。

[bigdata@hadoop102 kafka]$ kf.sh start

启动efak

[bigdata@hadoop102 efak]$ bin/ke.sh start

Version 2.0.8 -- Copyright 2016-2021

*****************************************************************

* EFAK Service has started success.

* Welcome, Now you can visit 'http://192.168.10.102:8048'

* Account:admin ,Password:123456

*****************************************************************

* <Usage> ke.sh [start|status|stop|restart|stats] </Usage>

* <Usage> https://www.kafka-eagle.org/ </Usage>

*****************************************************************

说明:如果停止efak,执行命令。

[bigdata@hadoop102 efak]$ bin/ke.sh stop

四、Kafka-Eagle页面操作

登录页面查看监控数据

http://192.168.10.102:8048/

五、总结

Kafka Eagle 提供了完善的管理页面,很方便的去管理和可视化Kafka集群的一些信息,例如Broker详情、性能指标趋势、Topic集合、消费者信息等,选它准没错,赶快安装试试吧。

最新文章
google 主页地址列表
google.com.hk 经常被屏蔽, 着实很不方便. 简单做个可用google主页地址统计. google.eu google.ad google.ae google.af google.ag google.al google.am google.as google.az google.ba google.be google.bf google.bg google.bi google.bo
bt手游盒子十大排名(2024最火爆的bt手游盒子大全)
最好玩的变态手游app有哪些?变态游戏平台一直是广大玩家们所感兴趣的,毕竟在里面有着海量的变态游戏,上线送GM破解工具,激活首充,基金,无限刷充、登录送无限资源,海量道具天天领,0氪也可以体验到土豪的游戏感受。所以下面18183手游网
Facebook推广效果不好?你知道如何提高Facebook广告数据转化吗?
社交媒体Facebook在海外市场也是有非常重要的地位的,使用 人数以及覆盖面积都是非常的可观,所以也是吸引了很多想要扩展国外市场的企业注意,作为广告推广平台。其中不乏很多推广效果非常的好的产品或者是企业,但是也有部分广告主反馈,
FairGuard游戏Lua加密方案解析
Lua以其小巧快速的特点已渐渐成为广大游戏开发者必修项,因此Lua的安全问题对于游戏开发者亦是迫在眉睫。 一. Lua 在手游中的使用场景 1.Cocos2dx 引擎 在 Cocos2dx 引擎中,可选的脚本语言主要有 Lua 与 Javascript。相对于 J
ChatGPT,带你进入未来聊天机器人时代
现代社会,聊天机器人已经成为了不可或缺的一部分。ChatGPT作为一款领先的聊天机器人开发工具,不仅具有高度的自然语言理解能力,还可以轻松实现各种场景下的对话交流。那么,让我们一起来探寻一下ChatGPT的魅力所在。首先,ChatGPT采用了
GAN介绍 - 提示与技巧
GAN介绍 - 介绍 https://blog.csdn.net/sean2100/article/details/83662975 GAN介绍 - 为什么学习生成式模型? https://blog.csdn.net/sean2100/article/details/83681043 GAN介绍 - 生成式模型是如何工作的? GAN与其他模型有什么区别࿱
### 怎样用自作脚本游戏:从教程到软件实操指南
在数字时代人工智能()的崛起不仅改变了咱们的生活和工作办法更在娱乐领域带来了一场革命。想象一下只需简单的指令就能帮助你创作出属于本人的脚本游戏。这不仅节省了大量的时间和精力还能让更多非专业人士参与到游戏制作的乐趣中来。本文
2025新东方《高二9科全科知识手册》电子版 全彩高清PDF百度网盘下载
2020某辅导(小猿搜题)高中辅导资料 百度网盘下载根据猿题库几千万学生的做题记录,选取高中生最易错、最常错的题型,精选整合,按照由易到难的原则排序,配以资深教师编写和答案详解。我们希望你在记忆前述的考点之后,通过练习典型例题,
(搜狐/知乎)代发业务排名
代发业务排名【--专业外推飞机TG:@xyseo6阿宝蜘蛛池--】代发业务排名【
Excel如何对成绩单排名
“苟延残喘”可以形容自己。拼音:gǒu yán cán chuǎn,原义是勉强延续临死前的喘息,比喻暂时勉强维持生存。出自北宋·欧阳修《与韩忠献王》:遽来居颖,苟存残喘,承赐恤问,敢此勉述。成语典故:狼是残暴的动物,本性难改。东郭先生
相关文章
推荐文章
发表评论
0评