Kubernetes安装和部署metrics-server
admin
2023-02-21 22:00:05
0

#一、metrics-server简介
自kubernetes 1.8开始,资源使用指标(如容器 CPU 和内存使用率)通过 Metrics API 在 Kubernetes 中获取,metrics-server 替代了heapster。Metrics Server 实现了Resource Metrics API,Metrics Server 是集群范围资源使用数据的聚合器。 
Metrics Server 从每个节点上的 Kubelet 公开的 Summary API 中采集指标信息。

Kubernetes中有些组件依赖资源指标API(metric API)的功能 ,如kubectl top 、hpa。如果没有资源指标API接口,这些组件无法运行。在之前使用的是Heapster,Heapster废弃后改用metrics-server。

  • 通过Metrics API可以获取指定node或者pod的当前资源使用情况(而无法获取历史数据)
  • Metrics API的api路径:/apis/metrics.k8s.io/
  • Metrics API的使用需要在K8S集群中成功部署metrics server

kubernetes metrics server 参考文档 https://github.com/kubernetes-incubator/metrics-server

#二、安装metrics-server

1、下载所需文件
# mkdir ./metrics-server  
# cd metrics-server/  
# for file in aggregated-metrics-reader.yaml auth-delegator.yaml auth-reader.yaml metrics-apiservice.yaml metrics-server-deployment.yaml metrics-server-service.yaml resource-reader.yaml; do  wget https://raw.githubusercontent.com/kubernetes-incubator/metrics-server/master/deploy/1.8%2B/$file;done 

2、这里需要改2个地方,一个是镜像的问题,一个是服务启动的问题。  

# 在所有Node节点上执行。先把镜像国通阿里云的镜像源下载下来。再改个名字。  
docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.3.3  
docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.3.3 k8s.gcr.io/metrics-server-amd64:v0.3.3  

# 修改metrics-server-deployment.yaml,增加一个imagePullPolicy,增加command内容,否则会报错no metrics known for node。相关问题原因自行百度。  
# vim metrics-server-deployment.yaml  
 30       containers:  
 31       - name: metrics-server  
 32         image: k8s.gcr.io/metrics-server-amd64:v0.3.3  
 33         imagePullPolicy: IfNotPresent  
 34         command:  
 35           - /metrics-server  
 36           - --kubelet-preferred-address-types=InternalIP,Hostname,InternalDNS,ExternalDNS,ExternalIP
 37           - --kubelet-insecure-tls  
 38         volumeMounts:  
 39         - name: tmp-dir  
 40           mountPath: /tmp  

# kubectl apply -f ./  

clusterrole.rbac.authorization.k8s.io/system:aggregated-metrics-reader created  
clusterrolebinding.rbac.authorization.k8s.io/metrics-server:system:auth-delegator created  
rolebinding.rbac.authorization.k8s.io/metrics-server-auth-reader created  
apiservice.apiregistration.k8s.io/v1beta1.metrics.k8s.io created 
serviceaccount/metrics-server created  
deployment.extensions/metrics-server created  
service/metrics-server created  
clusterrole.rbac.authorization.k8s.io/system:metrics-server created  
clusterrolebinding.rbac.authorization.k8s.io/system:metrics-server created  

3、查看pod状态  
metrics-server-55898485b6-pdhnz               1/1     Running   0          93m    10.244.4.2      huoban-k8s-node01  

4、查看node资源使用情况( 一定要等几分钟,采集数据需要时间) 
kubectl top node  
NAME                  CPU(cores)   CPU%   MEMORY(bytes)   MEMORY%     
huoban-k8s-master01   72m          3%     612Mi           16%         
huoban-k8s-master02   93m          4%     713Mi           19%         
huoban-k8s-master03   108m         5%     674Mi           18%         
huoban-k8s-node01     26m          1%     334Mi           9%          
huoban-k8s-node02     26m          1%     339Mi           9%        

5、查看pod资源使用情况
# kubectl top pods -n kube-system
NAME                                          CPU(cores)   MEMORY(bytes)
coredns-6967fb4995-4qlfb                      1m           13Mi
coredns-6967fb4995-frv2p                      1m           12Mi
etcd-huoban-k8s-master01                      22m          358Mi
etcd-huoban-k8s-master02                      25m          364Mi
etcd-huoban-k8s-master03                      23m          381Mi
kube-apiserver-huoban-k8s-master01            15m          267Mi
kube-apiserver-huoban-k8s-master02            13m          255Mi
kube-apiserver-huoban-k8s-master03            17m          249Mi
kube-controller-manager-huoban-k8s-master01   7m           69Mi
kube-controller-manager-huoban-k8s-master02   0m           14Mi
kube-controller-manager-huoban-k8s-master03   0m           14Mi
kube-flannel-ds-amd64-6bp76                   1m           21Mi
kube-flannel-ds-amd64-nrvvz                   1m           15Mi
kube-flannel-ds-amd64-shv4n                   1m           16Mi
kube-flannel-ds-amd64-t77n4                   1m           15Mi
kube-proxy-8d522                              1m           19Mi
kube-proxy-9ng4j                              1m           18Mi
kube-proxy-htw7p                              1m           20Mi
kube-proxy-n9r48                              1m           17Mi
kube-proxy-nsqgh                              1m           17Mi
kube-scheduler-huoban-k8s-master01            1m           27Mi
kube-scheduler-huoban-k8s-master02            0m           16Mi
kube-scheduler-huoban-k8s-master03            0m           13Mi
kubernetes-dashboard-86844cc55f-sz4gn         0m           13Mi
metrics-server-d9d75756b-l75wj                1m           17Mi   

相关内容

热门资讯

产能被冻、损失五百亿,阿联酋“... 阿联酋正式退出欧佩克,令这个成立了60多年、对全球油价都有着决定性影响的海湾核心组织公开决裂。欧佩克...
煤气灶火焰调什么颜色才最佳 良好的燃烧器,火焰呈浅蓝色,火力旺盛,火苗高度大小均匀一致。煤气灶火焰调节方式:1、将灶阀开到最大。...
柏特燃气灶中间没火怎么办 当我们使用柏特燃气灶时,出现中间没有火的情况可能是由多种原因引起的。以下是一些常见的原因和解决方法:...
火王燃气灶右边灶头打不着火 1、没有燃气。打不着火的情况大部分都是没有气了或者天然气管道堵塞所导致的,或者突发情况导致燃气公司关...
厨房橱柜开太快导致炉子熄火怎么... 1、使用燃气灶时,不要将燃气灶的门关的过紧导致气流不流通,从而间接导致炉子熄火的现象频发。2、在橱柜...
天然气火没关,把阀门关了 天然气火没关,把阀门关了如果只是一次这样做,不会造成安全问题,但最好将燃气灶具开关关闭,如果灶具使用...
金建希案主审法官坠亡,揭开韩国... ·申宗旿(中)在主持庭审。(韩联社)这一事件无疑已成为观察韩国司法独立现状的重要切片。作者:刘 潇当...
赖清德“偷渡式”窜访斯威士兰,... 台湾地区领导人赖清德此前因有关国家拒绝发放包机飞行许可,窜访斯威士兰受挫。5月2日,赖清德偷偷钻进斯...
28.5亿元建的高标准农田,“... 设备未安装、泵房被废弃、水渠不通水、农田灌溉难……鄱阳县部分高标准农田建设的问题正凸显出来。据澎湃新...
风声丨3万元即可入刑,史上最严... 作者丨胡敏洁浙江大学光华法学院教授、法律与社会政策研究中心主任长期以来,医药购销领域的腐败问题,始终...