K8S的Kafka监控(Prometheus+Grafana)
欢迎访问我的GitHub
https://github.com/zq2599/blog_demos
内容:所有原创文章分类汇总及配套源码,涉及Java、Docker、Kubernetes、DevOPS等;
对于部署在K8S上的Kafka来说,<font color="blue">Prometheus+Grafana</font>是常用的监控方案,今天就来实战通过Prometheus+Grafana监控K8S环境的Kafka;
准备工作
今天聚焦的是Kafka监控,因此需要K8S、Helm、Kafka、Prometheus、Grafana等服务都已就绪,下面提供了一些链接,在您做相关部署时可以作为参考:
- 搭建K8S:《kubespray2.11安装kubernetes1.15》
- 搭建Helm:《部署和体验Helm(2.16.1版本)》
- 搭建Prometheus和Grafana:《kubernetes1.15极速部署prometheus和grafana》
- 部署Kafka:《K8S环境快速部署Kafka(K8S外部可访问)》
版本信息
- Kubernetes:1.15
- Kubernetes宿主机:CentOS Linux release 7.7.1908
- NFS服务:IP地址192.168.50.135,文件夹/volume1/nfs-storageclass-test
- Helm:2.16.1
- Kafka:2.0.1
- Zookeeper:3.5.5
- Prometheus:2.0.0
- Grafana:5.0.0
准备完毕就可以开始实战了;
确认kafka-exporter参数
即将部署的kafka-exporter要从kafka取得数据,因此要准备kafka-exporter参数;
- 查看kafka的服务中TYPE是ClusterIP的那个,如下图红框所示:
- 上述红框中的服务名字是<font color="blue">kafka</font>、端口是<font color="blue">9092</font>,因此稍后在kafka-exporter中配置的kafka信息就是<font color="blue">kafka:9092</font>
实际操作
- 添加Helm仓库(该仓库中有我们需要的kafka-exporter):<font color="blue">helm repo add gkarthiks https://gkarthiks.github.io/helm-charts</font>
- 下载kafka-exporter:<font color="blue">helm fetch gkarthiks/prometheus-kafka-exporter</font>
- 解压下载的chart文件:<font color="blue">tar -zxvf prometheus-kafka-exporter-0.1.0.tgz</font>
- 进入解压后的目录:<font color="blue">cd prometheus-kafka-exporter</font>
- 修改values.yaml文件,如下图红框,<font color="blue">kafka:9092</font>就是同一namespace下访问kafka的地址:
- 在values.yaml文件所在目录执行:<font color="blue">helm install --name-template kafka-exporter -f values.yaml . --namespace kafka-test</font> (kafka的namespace是kafka-test,这里的namespace要和kafka保持一致)
- 查看服务和pod是否就绪:
- 此时我们部署好了<font color="blue">kafka-exporter</font>,能给prometheus提供监控数据了,但prometheus并不知道要来这里采集数据,因此接下来要配置prometheus;
- 确认<font color="blue">kafka-exporter</font>服务的访问地址,prometheus采集数据要用到,名字和端口如下图红框所示,因此可以拼接处跨namespace的访问地址:<font color="blue">kafka-exporter-prometheus-kafka-exporter.kafka-test.svc.cluster.local:9308</font>
- 如果您是参照《kubernetes1.15极速部署prometheus和grafana》部署的prometheus,请打开部署时下载的<font color="blue">configmap.yaml</font>文件,里面是prometheus的配置,如果是其他途径部署的,请按照自己的部署情况找到prometheus.yml的位置;
- <font color="blue">configmap.yaml</font>中增加下图红框中的内容,这样prometheus就可以采集kafka-exporter的数据了:
- 使得配置生效:<font color="blue">kubectl apply -f configmap.yaml</font>
- 此时的prometheus容器用的还是旧配置,为了让配置生效,要把prometheus的pod删除,这样K8S自动创建的新pod就用上了新的配置,找出prometheus的pod:<font color="blue">kubectl get pods -n kube-system</font>
- 删除旧的pod:<font color="blue">kubectl delete pod prometheus-68545d4fd8-f5q2w -n kube-system</font>
- 等待新的pod被自动创建;
- 接下来登录Grafana,配置监控页面,如下图,做模板导入操作:
- 在导入模板的页面输入编号7589:
- 选择数据源的时候,要选prometheus,如下图:
- 此时如果您的kafka有消息的收发,就可以立即看到数据了:
至此,K8S环境下的kafka监控已经部署完成,希望本文能给您一些参考;
欢迎关注公众号:程序员欣宸
微信搜索「程序员欣宸」,我是欣宸,期待与您一同畅游Java世界... https://github.com/zq2599/blog_demos

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
你知道几种前端动画的实现方式?
随着互联网的持续发展,H5 页面作为与用户直接交互的表现层越来越复杂,呈现的形式也越来越丰富,从而也要求 H5 页面具有更多的花样性及动画效果。那前端实现动画效果的方式有哪些呢,大致有如下几种: 一、GIF图片 GIF图就直接贴上图片就好了,使用非常简单,但GIF图有时出现问题是没办法控制的,比如常见的GIF图的闪烁现象。 二、序列帧 序列帧其实本质是GIF图单个帧的铺开,结合css animation一种实现方式。 具体实现方式如下: 主要用到的就是animation的steps函数,兼容性还是非常不错的。 序列帧在 H5 开发中手机分辨率的不同,可能有轻微抖动现象,可通过将该dom嵌套到SVG 中解决。 三、css animation animation 属性用来指定一组或多组动画,每组之间用逗号相隔。 /* @keyframes duration | timing-function | delay | name */ animation: 3s linear 1s slidein; @keyframes slidein { from { transform: ...
- 下一篇
一路踩坑,被迫聊聊 C# 代码调试技巧和远程调试
一:背景 1. 讲故事 每次项目预交付的时候,总会遇到各种奇葩的坑,我觉得有必要梳理一下以及如何快速解决的,让后来人避避坑,这篇就聊聊自己的所闻所遇: 我去,本地环境代码跑的哧溜,上了测试环境出问题 我去, 第三方提供的 dll 跑出 bug 了 二:两个大坑的解决方案 1. 本地环境没问题,上了测试出问题 相信很多朋友都有我这样类似的遭遇,明明程序代码,配置文件都一样,挪了一个窝就出问题,你说气人不,既然问题出了那怎么快速解决呢? 对,就是用调试,但程序部署在 centos 上,送一个 visualstudio 上去也不现实,在这种限制级条件下还想调试怎么办呢?不错,可以上远程调试,然后就很快查到了测试机器中的某一个环境变量搞错了,事情的来龙去脉搞清楚了,接下来就看看怎么实现 local 到 centos 的 远程调试。 1) 测试代码 为了方便演示,我就在 Action 中读取 strategy 环境变量。 public class HomeController : Controller { public IActionResult Index() { ViewBag.strate...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker安装Oracle12C,快速搭建Oracle学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS关闭SELinux安全模块
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Docker使用Oracle官方镜像安装(12C,18C,19C)