欢送拜访我的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/h...</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