k8s实践(十二):Prometheus Operator监控Kubernetes集群
admin
2023-02-27 14:21:05
0

环境说明:

主机名 操作系统版本 ip docker version kubelet version helm version 配置 备注
master Centos 7.6.1810 172.27.9.131 Docker 18.09.6 V1.14.2 v2.14.3 2C2G master主机
node01 Centos 7.6.1810 172.27.9.135 Docker 18.09.6 V1.14.2 v2.14.3 2C2G node节点
node02 Centos 7.6.1810 172.27.9.136 Docker 18.09.6 V1.14.2 v2.14.3 2C2G node节点

 

k8s集群部署详见:Centos7.6部署k8s(v1.14.2)集群
k8s学习资料详见:基本概念、kubectl命令和资料分享
k8s高可用集群部署详见:Centos7.6部署k8s v1.16.4高可用集群(主备模式)
 

一、prometheus简介

Prometheus是一个开源系统监控和警报工具包,最初是在soundcloud构建的。自2012年成立以来,许多公司和组织都采用了Prometheus,该项目拥有一个非常活跃的开发人员和用户社区。它现在是一个独立的开源项目,独立于任何公司进行维护,于2016年加入了云原生计算基金会,成为继kubernetes之后的第二个托管项目。

特点:

  • 用度量名和键值对识别时间序列数据的多维数据模型
  • 灵活的查询语言
  • 不依赖分布式存储;单服务器节点是自治的
  • 通过http上的pull模型进行时间序列收集
  • 通过中间网关支持推送时间序列
  • 通过服务发现或静态配置发现目标
  • 多种图形和仪表板支持模式

在微服务架构里,其对多维数据收集和查询有很好的的支持。

二、prometheus架构

k8s实践(十二):Prometheus Operator监控Kubernetes集群

Prometheus从jobs获取度量数据,也直接或通过推送网关获取临时jobs的度量数据。它在本地存储所有被获取的样本,并在这些数据运行规则,对现有数据进行聚合和记录新的时间序列,或生成警报。通过Grafana或其他API消费者,可以可视化的查看收集到的数据。

三、Prometheus Operator介绍

Prometheus Operator是CoreOS开发的基于Prometheus的Kubernetes监控方案

k8s实践(十二):Prometheus Operator监控Kubernetes集群

Prometheus Operator:整合Kubernetes和Prometheus的最佳方法

Prometheus Operator 功能更特点:

  • 创建/销毁: 在Kubernetes namespace中更容易启动一个prometheus实例,一个特定的应用程序或团队更容易使用Operator。
  • 简单配置: 配置Prometheus的基础,比如versions, persistence, retention policies和来自本机kubernetes资源的副本。
  • 通过标签的目标服务: 基于常见的Kubernetes label查询,自动生成监控target 配置;无需学习prometheus特定的配置语言。

工作流程:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

四、Prometheus Operator部署

1.安装文件下载

[root@master ~]# git clone https://github.com/coreos/kube-prometheus.git

k8s实践(十二):Prometheus Operator监控Kubernetes集群

2.镜像下载

下载镜像:

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/configmap-reload:v0.0.1

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/alertmanager:v0.18.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/kube-state-metrics:v1.8.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/kube-rbac-proxy:v0.4.1

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/node-exporter:v0.18.1

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/k8s-prometheus-adapter-amd64:v0.5.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-config-reloader:v0.33.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/prometheus:v2.11.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-operator:v0.33.0

docker pull registry.cn-hangzhou.aliyuncs.com/loong576/grafana:6.4.3

打tag:

docker tag  registry.cn-hangzhou.aliyuncs.com/loong576/configmap-reload:v0.0.1 quay.io/coreos/configmap-reload:v0.0.1

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/alertmanager:v0.18.0 quay.io/prometheus/alertmanager:v0.18.0

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/kube-state-metrics:v1.8.0 quay.io/coreos/kube-state-metrics:v1.8.0

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/kube-rbac-proxy:v0.4.1 quay.io/coreos/kube-rbac-proxy:v0.4.1

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/node-exporter:v0.18.1  quay.io/prometheus/node-exporter:v0.18.1

docker tag  registry.cn-hangzhou.aliyuncs.com/loong576/k8s-prometheus-adapter-amd64:v0.5.0 quay.io/coreos/k8s-prometheus-adapter-amd64:v0.5.0

docker tag  registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-config-reloader:v0.33.0 quay.io/coreos/prometheus-config-reloader:v0.33.0

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/prometheus:v2.11.0 quay.io/prometheus/prometheus:v2.11.0

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-operator:v0.33.0  quay.io/coreos/prometheus-operator:v0.33.0

docker tag registry.cn-hangzhou.aliyuncs.com/loong576/grafana:6.4.3 grafana/grafana:6.4.3

删除镜像:

docker rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/configmap-reload:v0.0.1

docker rmi -f registry.cn-hangzhou.aliyuncs.com/loong576/alertmanager:v0.18.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/kube-state-metrics:v1.8.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/kube-rbac-proxy:v0.4.1

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/node-exporter:v0.18.1

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/k8s-prometheus-adapter-amd64:v0.5.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-config-reloader:v0.33.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/prometheus:v2.11.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/prometheus-operator:v0.33.0

docker  rmi -f  registry.cn-hangzhou.aliyuncs.com/loong576/grafana:6.4.3

以上三个步骤所有node节点都执行

3.执行安装

[root@master kube-prometheus]# kubectl create -f manifests/setup
[root@master kube-prometheus]# kubectl create -f manifests/

4.资源查看

[root@master kube-prometheus]# kubectl get all -n monitoring 
[root@master kube-prometheus]# kubectl get prometheus --all-namespaces -o wide

k8s实践(十二):Prometheus Operator监控Kubernetes集群

所有资源都在monitoring命名空间中。

5.更改访问方式

[root@master kube-prometheus]# kubectl edit -n monitoring service prometheus-k8s
service/prometheus-k8s edited
[root@master kube-prometheus]# kubectl edit -n monitoring service grafana
service/grafana edited
[root@master kube-prometheus]# kubectl edit -n monitoring service alertmanager-main
service/alertmanager-main edited

k8s实践(十二):Prometheus Operator监控Kubernetes集群

分别修改service prometheus-k8s、grafana和alertmanager-main,service类型为NodePort,端口分别为30021、30022、30023

五、页面展示

1.访问 Prometheus

http://172.27.9.131:30021

k8s实践(十二):Prometheus Operator监控Kubernetes集群

k8s实践(十二):Prometheus Operator监控Kubernetes集群

2.访问 Alert Manager

http://172.27.9.131:30023

k8s实践(十二):Prometheus Operator监控Kubernetes集群
k8s实践(十二):Prometheus Operator监控Kubernetes集群

3.访问 Grafana

http://172.27.9.131:30022 用户名密码都为admin

k8s实践(十二):Prometheus Operator监控Kubernetes集群

内置模板查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

集群资源查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

kubelet查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

StatefulSets查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

Pod查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

API查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

namespace查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

查看各节点资源使用:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

Prometheus查看:

k8s实践(十二):Prometheus Operator监控Kubernetes集群

其他模板:

自带的模板很丰富,不过也可以下载其他模板,比如 ‘1 Node Exporter for Prometheus 监控展示看板 update!’ :https://grafana.com/api/dashboards/8919/revisions/10/download

k8s实践(十二):Prometheus Operator监控Kubernetes集群

六、Prometheus Operator卸载

[root@master kube-prometheus]# kubectl delete --ignore-not-found=true -f manifests/ -f manifests/setup

本文所有脚本和配置文件已上传:k8s实践(十二):Prometheus Operator监控Kubernetes集群

相关内容

热门资讯

重磅消息“乐成棋牌.怎么开挂?... 有 亲,根据资深记者爆料乐成棋牌是可以开挂的,确实有挂(咨询软件无需打开...
终于明白“新版悟空牛牛.有挂吗... 有 亲,根据资深记者爆料新版悟空牛牛是可以开挂的,确实有挂(咨询软件无需...
终于明白“微乐陕西挖坑.怎么开... 家人们!今天小编来为大家解答微乐陕西挖坑透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里...
今日重大消息“夏天yy.可以开... 今日重大消息“夏天yy.可以开挂吗?”确实真的有挂您好,夏天yy这个游戏其实有挂的,确实是有挂的,需...
最新引进“同城乐吧.怎么装挂?... 有 亲,根据资深记者爆料同城乐吧是可以开挂的,确实有挂(咨询软件无需打开...
【第一财经】“山西大唐麻将.真... 您好:山西大唐麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款...
终于了解“兴义水鱼.是不是有挂... 网上科普关于“兴义水鱼有没有挂”话题很是火热,小编也是针对兴义水鱼作*弊开挂的方法以及开挂对应的知识...
玩家最新攻略“微信链接牛牛.有... 网上科普关于“微信链接牛牛有没有挂”话题很是火热,小编也是针对微信链接牛牛作*弊开挂的方法以及开挂对...
终于懂了“微乐贵阳麻将.究竟有... 终于懂了“微乐贵阳麻将.究竟有挂吗?”太坑了原来有挂您好,微乐贵阳麻将这个游戏其实有挂的,确实是有挂...
玩家攻略科普“蛮王牛牛.可以开... 有 亲,根据资深记者爆料蛮王牛牛是可以开挂的,确实有挂(咨询软件无需打开...