当前位置: 首页 > news >正文

十四、k8s集群安装kube-state-metrics 组件

kube-state-metrics 通过监听 API Server 生成有关资源对象的状态指标,比如Node、Pod,需 要注意的是kube-state-metrics 只是简单的提供一个metrics数据,并不会存储这些指标数据,所 以我们可以使用Prometheus来抓取这些数据然后存储,主要关注的是业务相关的一些元数据,比如 Pod 副本状态等;调度了多少个replicas?现在可用的有几个?多少个Pod是 running/stopped/terminated 状态?Pod 重启了多少次?我有多少job在运行中。

安装kube-state-metrics 组件

1)创建sa,并对sa授权

在master节点创建kube-state-metrics-rbac.yaml文件

vim kube-state-metrics-rbac.yaml

输入:

apiVersion: v1
kind: ServiceAccount
metadata:
name: kube-state-metrics
namespace: kube-system
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: kube-state-metrics
rules:
- apiGroups: [""]
resources:
- configmaps
- secrets
- nodes
- pods
- services
- resourcequotas
- replicationcontrollers
- limitranges
- persistentvolumeclaims
- persistentvolumes
- namespaces
- endpoints
verbs: ["list", "watch"]
- apiGroups: ["apps"]
resources:
- statefulsets
- daemonsets
- deployments
- replicasets
verbs: ["list", "watch"]
- apiGroups: ["batch"]
resources:
- cronjobs
- jobs
verbs: ["list", "watch"]
- apiGroups: ["autoscaling"]
resources:
- horizontalpodautoscalers
verbs: ["list", "watch"]
- apiGroups: ["policy"]
resources:
- poddisruptionbudgets
verbs: ["list", "watch"]
- apiGroups: ["certificates.k8s.io"]
resources:
- certificatesigningrequests
verbs: ["list", "watch"]
- apiGroups: ["storage.k8s.io"]
resources:
- storageclasses
- volumeattachments
verbs: ["list", "watch"]
- apiGroups: ["admissionregistration.k8s.io"]
resources:
- mutatingwebhookconfigurations
- validatingwebhookconfigurations
verbs: ["list", "watch"]
- apiGroups: ["networking.k8s.io"]
resources:
- networkpolicies
- ingresses
verbs: ["list", "watch"]
- apiGroups: ["coordination.k8s.io"]
resources:
- leases
verbs: ["list", "watch"]
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: kube-state-metrics
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: kube-state-metrics
subjects:
- kind: ServiceAccount
name: kube-state-metrics
namespace: kube-system

保存退出

kubectl apply -f kube-state-metrics-rbac.yaml

2)安装kube-state-metrics 组件

GitHub 官方仓库地址:

Releases · kubernetes/kube-state-metrics · GitHub

Docker Hub 官方镜像地址‌:直接拉取官方预构建镜像,无需本地编译

https://hub.docker.com/去这个地址里面搜索下载

ctr -n k8s.io images import kube-state-metrics_1_9_0.tar.gz

vim kube-state-metrics deploy.yaml

输入:

apiVersion: apps/v1
kind: Deployment
metadata:
name: kube-state-metrics
namespace: kube-system
spec:
replicas: 1
selector:
matchLabels:
app: kube-state-metrics
template:
metadata:
labels:
app: kube-state-metrics
spec:
serviceAccountName: kube-state-metrics
containers:
- name: kube-state-metrics
image: quay.io/coreos/kube-state-metrics:v1.9.0
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8080

保存退出

kubectl apply -f kube-state-metrics-deploy.yaml

查看kube-state-metrics是否部署成功

kubectl get pods -n kube-system -l app=kube-state-metrics

3)创建service

vim kube-state-metrics-svc.yaml

输入:

apiVersion: v1
kind: Service
metadata:
annotations:
prometheus.io/scrape: 'true'
name: kube-state-metrics
namespace: kube-system
labels:
app: kube-state-metrics
spec:
ports:
- name: kube-state-metrics
port: 8080
protocol: TCP
selector:
app: kube-state-metrics

保存退出

kubectl apply -f kube-state-metrics-svc.yaml

查看service是否创建成功

kubectl get svc -n kube-system | grep kube-state-metrics

去网站下载下面grafana可视化的json

Kubernetes Cluster (Prometheus)

Kubernetes cluster monitoring (via Prometheus) (k8s 1.16)

导入,就可以看数据了

http://www.jsqmd.com/news/1124511/

相关文章:

  • Java实战:从消息摘要到代码签名的完整数字签名与证书应用指南
  • STM32与EEPROM实现嵌入式低功耗数据存储方案
  • 网络安全入门:三个月实战路线与Kali Linux渗透测试核心技能
  • Windows智能体开发前瞻:从系统集成到实战应用
  • 若依框架定时任务安全风险深度剖析与加固实战指南
  • 高温环境三轴机械手气动控制系统设计与实现
  • 大模型工具调用能力评测:从单次API调用到多轮状态协同
  • 如何专业地拒绝不合规的AI内容创作请求
  • SQL注入绕过WAF的实战思路与九大技巧详解
  • Hermes Agent 保姆级安装配置指南:从零搭建具备学习能力的AI智能伙伴
  • 从LeNet到AlexNet:PyTorch实战解析两大经典卷积神经网络架构
  • 从Nmap侦察到Hydra暴力破解:Metasploitable2靶场Telnet渗透实战
  • 终极指南:如何在Blender中直接导入Rhino 3D文件?
  • 国产大模型选型实战指南:按任务类型匹配GLM5、Kimi、千问等五款主力模型
  • 基于霍夫圆变换的GIF人脸替换技术实现
  • 基于YOLOv8的藻类细胞检测系统设计与实现
  • 锂离子电池电量监测技术及LC709204V芯片应用解析
  • 告别繁琐操作:如何用League-Toolkit让英雄联盟游戏体验提升300%
  • Wireshark实战:图解PCIe链路训练与LTSSM状态机调试
  • HS工具箱:免费在线万能工具集使用与自建指南
  • 医疗AI可解释性实战:用LangGraph+SHAP+MCP构建临床可信预测系统
  • Java计算机毕设之庭院景观定制设计服务管理系统的设计与实现 园林景观施工项目台账管理系统(完整前后端代码+说明文档+LW,调试定制等)
  • WeatherBench:AI气象模型的标准化评测基准与实操指南
  • 基于YOLOv8的电梯电动车实时检测系统设计与实现
  • 基于YOLOv11的车辆零部件缺陷智能检测系统开发
  • LangChain Agents实战:构建自主决策AI工作流
  • KMR221与PIC18F2525实现高精度电压监测方案
  • 7天掌握LangChain:从零开发AI应用的实战指南
  • AI原生应用开发全栈指南:从架构到部署
  • KeymouseGo:5分钟掌握免费鼠标键盘录制工具,彻底告别重复操作