首页 > 其他分享 >K8S的Kafka监控(Prometheus+Grafana)

K8S的Kafka监控(Prometheus+Grafana)

时间:2022-12-17 21:34:14浏览次数:79  
标签:exporter Grafana 部署 prometheus kafka Prometheus K8S Kafka

欢迎访问我的GitHub

这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos

  • 对于部署在K8S上的Kafka来说, Prometheus+Grafana 是常用的监控方案,今天就来实战通过Prometheus+Grafana监控K8S环境的Kafka;

准备工作

  • 今天聚焦的是Kafka监控,因此需要K8S、Helm、Kafka、Prometheus、Grafana等服务都已就绪,下面提供了一些链接,在您做相关部署时可以作为参考:
  1. 搭建K8S:《kubespray2.11安装kubernetes1.15》
  2. 搭建Helm:《部署和体验Helm(2.16.1版本)》
  3. 搭建Prometheus和Grafana:《kubernetes1.15极速部署prometheus和grafana》
  4. 部署Kafka:《K8S环境快速部署Kafka(K8S外部可访问)》

版本信息

  1. Kubernetes:1.15
  2. Kubernetes宿主机:CentOS Linux release 7.7.1908
  3. NFS服务:IP地址192.168.50.135,文件夹/volume1/nfs-storageclass-test
  4. Helm:2.16.1
  5. Kafka:2.0.1
  6. Zookeeper:3.5.5
  7. Prometheus:2.0.0
  8. Grafana:5.0.0
  • 准备完毕就可以开始实战了;

确认kafka-exporter参数

  • 即将部署的kafka-exporter要从kafka取得数据,因此要准备kafka-exporter参数;
  • 查看kafka的服务中TYPE是ClusterIP的那个,如下图红框所示: 在这里插入图片描述
  • 上述红框中的服务名字是 kafka 、端口是 9092 ,因此稍后在kafka-exporter中配置的kafka信息就是 kafka:9092

实际操作

  • 添加Helm仓库(该仓库中有我们需要的kafka-exporter): helm repo add gkarthiks https://gkarthiks.github.io/helm-charts
  • 下载kafka-exporter: helm fetch gkarthiks/prometheus-kafka-exporter
  • 解压下载的chart文件: tar -zxvf prometheus-kafka-exporter-0.1.0.tgz
  • 进入解压后的目录: cd prometheus-kafka-exporter
  • 修改values.yaml文件,如下图红框, ** kafka:9092 就是同一namespace下访问kafka的地址: 在这里插入图片描述
  • 在values.yaml文件所在目录执行: helm install --name-template kafka-exporter -f values.yaml . --namespace kafka-test (kafka的namespace是kafka-test,这里的namespace要和kafka保持一致)
  • 查看服务和pod是否就绪: 在这里插入图片描述
  • 此时我们部署好了 kafka-exporter ,能给prometheus提供监控数据了,但prometheus并不知道要来这里采集数据,因此接下来要配置prometheus;
  • 确认 kafka-exporter 服务的访问地址,prometheus采集数据要用到,名字和端口如下图红框所示,因此可以拼接处跨namespace的访问地址: kafka-exporter-prometheus-kafka-exporter.kafka-test.svc.cluster.local:9308 在这里插入图片描述
  • 如果您是参照《kubernetes1.15极速部署prometheus和grafana》部署的prometheus,请打开部署时下载的 configmap.yaml 文件,里面是prometheus的配置,如果是其他途径部署的,请按照自己的部署情况找到prometheus.yml的位置;
  • configmap.yaml 中增加下图红框中的内容,这样prometheus就可以采集kafka-exporter的数据了: 在这里插入图片描述
  • 使得配置生效: kubectl apply -f configmap.yaml
  • 此时的prometheus容器用的还是旧配置,为了让配置生效,要把prometheus的pod删除,这样K8S自动创建的新pod就用上了新的配置,找出prometheus的pod: kubectl get pods -n kube-system 在这里插入图片描述
  • 删除旧的pod: kubectl delete pod prometheus-68545d4fd8-f5q2w -n kube-system
  • 等待新的pod被自动创建;
  • 接下来登录Grafana,配置监控页面,如下图,做模板导入操作: 在这里插入图片描述
  • 在导入模板的页面输入编号7589: 在这里插入图片描述
  • 选择数据源的时候,要选prometheus,如下图: 在这里插入图片描述
  • 此时如果您的kafka有消息的收发,就可以立即看到数据了: 在这里插入图片描述
  • 至此,K8S环境下的kafka监控已经部署完成,希望本文能给您一些参考;

欢迎关注51CTO博客:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...

标签:exporter,Grafana,部署,prometheus,kafka,Prometheus,K8S,Kafka
From: https://blog.51cto.com/zq2599/5950145

相关文章

  • 【云原生】Prometheus 自定义告警规则
    目录一、概述二、告警实现流程三、告警规则1)告警规则配置1)监控服务器是否在线3)告警数据的状态四、实战操作1)下载node_exporter2)启动node_exporter3)配置Prometheus加载nod......
  • K8S基础-POD
    1.1POD1.1.1创建一个pod定义一个pod(分层使用两个空格,勿用tab键)#vimnginx.yamlapiVersion:v1#必选,API的版本号kind:Pod#必选,类型Podmetadata:#必......
  • K8s-发布方式浅谈
    K8s-发布方式浅谈蓝绿发布环境存在两个版本,蓝版本和绿版本同时存在,部署新版本然后进行测试,将流量切到新版本,最终实际运行的只有一个版本(蓝/绿)。好处是无需停机,并......
  • 解决k8s中service暴露的端口使用公网ip无法访问
    背景在华为云服务器上使用kk工具安装k8s+kubesphere,正常安装后无法通过公网ip+端口号的方式访问kubesphere页面(ps:华为云上的安全组已经放开)解决办法在命令行执行iptable......
  • k8s 网络抓包
    背景工具介绍nsenter是一款可以进入进程的名称空间中。例如,如果一个容器以非root用户身份运行,而使用 ​​dockerexec​​​ 进入其中后,但该容器没有安装 ​​sudo​......
  • K8S集群安装Istio服务网格
     下载地址​​ReleaseIstio1.11.4·istio/istio·GitHubConnect,secure,control,andobserveservices.Contributetoistio/istiodevelopmentbycreatingan......
  • k8s 镜像下载并上传
    该脚本用于将多个版本的k8s官方的镜像及二进制文件下载到本地,并将镜像上传到自己的docker仓库中去直接运行即可(需要保障运行脚本的机器能够访问k8s镜像仓库,并且已经登陆了......
  • 部署k8s详细步骤(避坑版)
    部署k8s详细步骤(避坑版)一、docker部署1.命令一键安装(公网)curl-fsSLhttps://get.docker.com|bash-sdocker--mirrorAliyun2.启动并查看docker状态systemctlena......
  • 【云原生 | Kubernetes篇】自建高可用k8s集群搭建
    文末有惊喜文章目录​​自建高可用k8s集群搭建​​​​一、所有节点基础环境​​​​1、环境准备与内核升级​​​​2、安装Docker​​​​二、PKI​​​​三、证书工具准备......
  • Kubernetes(k8s) kubectl rollout resume常用命令
    kubectl在$HOME/.kube目录中查找一个名为config的配置文件。可以通过设置KUBECONFIG环境变量或设置--kubeconfig参数来指定其它kubeconfig文件。本文主要介绍K......