Kubernetes(k8s):部署、使用 metrics-server

Kubernetes(k8s):部署、使用 metrics-server

  • 一、metrics-server简介
  • 二、部署metrics-server
    • [2.1、 下载 Metrics Server 部署文件](#2.1、 下载 Metrics Server 部署文件)
    • [2.2、修改metrics-server.yaml 文件](#2.2、修改metrics-server.yaml 文件)
    • [2.3、 部署 Metrics Server](#2.3、 部署 Metrics Server)
    • [2.4、 检查 Metrics Server](#2.4、 检查 Metrics Server)
  • [三、使用 Metrics Server](#三、使用 Metrics Server)

|-----------------------------|
| 💖The Begin💖点点关注,收藏不迷路💖 |

基于Kubernetes 集群,并已经安装并配置好 kubectl 工具。

一、metrics-server简介

Metrics Server 可以帮助我们监控集群中节点和容器的资源使用情况。

在本篇 CSDN 博客中,我将详细介绍如何部署 Metrics Server 到 Kubernetes 集群中。


工作流程说明:

1、用户执行 kubectl top 命令,向 Metrics Server 发送查询请求。

2、Metrics Server 接收到查询请求后,向 kubelet/cAdvisor 发送请求获取容器的资源使用情况数据。

3、kubelet/cAdvisor 是运行在每个节点上的组件,负责收集和暴露容器的资源使用情况数据。它收到 Metrics Server 的请求后,查询本地 cAdvisor,并收集相应的数据。

4、kubelet/cAdvisor 将收集到的数据返回给 Metrics Server。

5、Metrics Server 对收集到的数据进行处理,并将处理后的结果返回给用户,用户可以通过命令行工具或其他监控工具查看容器的资源使用情况。

二、部署metrics-server

2.1、 下载 Metrics Server 部署文件

Kubernetes Metrics Server 的版本与 Kubernetes 版本之间的兼容性矩阵:

从 Metrics Server 的 GitHub 仓库下载部署文件。执行以下命令:

sql 复制代码
wget https://github.com/kubernetes-sigs/metrics-server/releases/download/v0.6.4/components.yaml

##将文件名更改为 metrics-server.yaml
mv components.yaml metrics-server.yaml

2.2、修改metrics-server.yaml 文件

sql 复制代码
containers:
- args:
  - --cert-dir=/tmp
  - --secure-port=4443
  - --kubelet-preferred-address-types=InternalIP # 第一处修改
  - --kubelet-use-node-status-port
  - --metric-resolution=15s
  - --kubelet-insecure-tls # 第二处修改
  image: registry.aliyuncs.com/google_containers/metrics-server:v0.6.4 # 第三处修改
  imagePullPolicy: IfNotPresent

1、将 --kubelet-preferred-address-types 参数的值修改为 InternalIP,这表示 Metrics Server 将首选使用节点的 InternalIP 地址与 Kubelet 进行通信。

2、添加 --kubelet-insecure-tls 参数,这表示 Metrics Server 将使用不安全的 TLS 连接与 Kubelet 通信。请注意,这会降低通信的安全性,只应该在测试环境中使用。

3、将 image 字段的值修改为 registry.aliyuncs.com/google_containers/metrics-server:v0.7.1,这表示使用阿里云容器镜像服务中的 Metrics Server v0.7.1 版本。

2.3、 部署 Metrics Server

部署 Metrics Server 到你的 Kubernetes 集群中。

sql 复制代码
[root@k8s-master ~]#  kubectl apply -f metrics-server.yaml
serviceaccount/metrics-server created
clusterrole.rbac.authorization.k8s.io/system:aggregated-metrics-reader created
clusterrole.rbac.authorization.k8s.io/system:metrics-server created
rolebinding.rbac.authorization.k8s.io/metrics-server-auth-reader created
clusterrolebinding.rbac.authorization.k8s.io/metrics-server:system:auth-delegator created
clusterrolebinding.rbac.authorization.k8s.io/system:metrics-server created
service/metrics-server created
deployment.apps/metrics-server created
apiservice.apiregistration.k8s.io/v1beta1.metrics.k8s.io created
[root@k8s-master ~]#

2.4、 检查 Metrics Server

在一段时间后通过运行 kubectl get pods -n kube-system 命令来检查 Metrics Server 是否成功启动并运行。

sql 复制代码
kubectl get pods -n kube-system 

或者

##获取到具有标签 k8s-app=metrics-server 的 pods 列表
kubectl get pods -n kube-system -l k8s-app=metrics-server


三、使用 Metrics Server

Metrics Server 部署完成后,你就可以开始使用它了。

Metrics Server 会收集关于集群资源使用情况的指标数据,你可以使用 kubectl top 命令查看节点和容器的使用情况:

3.1、 查看节点使用情况

sql 复制代码
kubectl top nodes

3.2、查看命名空间中所有容器的使用情况

sql 复制代码
kubectl top pods -n <namespace>

kubectl top pods -n kube-system 

|---------------------------|
| 💖The End💖点点关注,收藏不迷路💖 |

相关推荐
容器魔方2 小时前
中选名单出炉|18位学生入选开源之夏KubeEdge课题,欢迎加入!
云原生·容器·云计算
love530love4 小时前
Docker 稳定运行与存储优化全攻略(含可视化指南)
运维·人工智能·windows·docker·容器
人生匆匆4 小时前
docker进入启动失败的容器
运维·docker·容器
退役小学生呀6 小时前
十、K8s集群资源合理化分配
linux·云原生·容器·kubernetes·k8s
yanjiaweiya7 小时前
云原生-集群管理
java·开发语言·云原生
yanjiaweiya9 小时前
云原生-集群管理续
java·开发语言·云原生
Johny_Zhao15 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
代码老y18 小时前
Docker:容器化技术的基石与实践指南
运维·docker·容器
掘金-我是哪吒1 天前
分布式微服务系统架构第156集:JavaPlus技术文档平台日更-Java线程池使用指南
java·分布式·微服务·云原生·架构
阿里云云原生1 天前
Serverless JManus: 企业生产级通用智能体运行时
云原生