K8S实践Ⅸ(集群监控)
admin
2023-03-09 03:02:33
0

一、PrometheusOperator介绍

PrometheusOperator是CoreOS开源的一套用于管理在Kubernetes集群上的Prometheus的控制器,简化在Kubernetes上部署、管理和运行Prometheus和Alertmanager集群的操作。

二、部署

1.从官方下载部署文件

# git clone https://github.com/coreos/kube-prometheus.git

2.更改镜像仓库地址

# mkdir prometheus
# cp kube-prometheus/manifests/* prometheus/
# sed -i 's#k8s.gcr.io#gcr.azk8s.cn/google_containers#g' prometheus/*
# sed -i 's#quay.io#quay.azk8s.cn#g' prometheus/*
# cat prometheus/* | grep image

3.部署所有资源

# kubectl apply -f prometheus/

4.查看创建的ns和crd

# kubectl get ns |grep monitoring
monitoring        Active   3m30s
# kubectl get crd
NAME                                    CREATED AT
alertmanagers.monitoring.coreos.com     2019-09-10T09:13:00Z
podmonitors.monitoring.coreos.com       2019-09-10T09:13:00Z
prometheuses.monitoring.coreos.com      2019-09-10T09:13:01Z
prometheusrules.monitoring.coreos.com   2019-09-10T09:13:02Z
servicemonitors.monitoring.coreos.com   2019-09-10T09:13:03Z

5.查看monitoring下所有的pod和svc

# kubectl get pod -n monitoring
NAME                                   READY   STATUS    RESTARTS   AGE
alertmanager-main-0                    2/2     Running   0          23h
alertmanager-main-1                    2/2     Running   0          23h
alertmanager-main-2                    2/2     Running   0          23h
grafana-57bfdd47f8-bhkvv               1/1     Running   0          23h
kube-state-metrics-8cf4797dc-7dg4w     4/4     Running   0          23h
node-exporter-446xd                    2/2     Running   0          23h
node-exporter-8sbsf                    2/2     Running   0          23h
node-exporter-dk7qk                    2/2     Running   0          23h
node-exporter-vdsqg                    2/2     Running   0          23h
node-exporter-w7czt                    2/2     Running   0          23h
node-exporter-wx7vj                    2/2     Running   0          23h
prometheus-adapter-6b9989ccbd-bcl2h    1/1     Running   0          23h
prometheus-k8s-0                       3/3     Running   1          23h
prometheus-k8s-1                       3/3     Running   1          23h
prometheus-operator-7894d75578-rg2gl   1/1     Running   0          23h
# kubectl get svc -n monitoring
NAME                    TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)                      AGE
alertmanager-main       NodePort    10.97.155.71            9093:30093/TCP               23h
alertmanager-operated   ClusterIP   None                    9093/TCP,9094/TCP,9094/UDP   23h
grafana                 NodePort    10.110.28.251           3000:30030/TCP               23h
kube-state-metrics      ClusterIP   None                    8443/TCP,9443/TCP            23h
node-exporter           ClusterIP   None                    9100/TCP                     23h
prometheus-adapter      ClusterIP   10.111.75.114           443/TCP                      23h
prometheus-k8s          NodePort    10.109.3.70             9090:30090/TCP               23h
prometheus-operated     ClusterIP   None                    9090/TCP                     23h
prometheus-operator     ClusterIP   None                    8080/TCP                     23h

6.更改端口模式为NodePort映射端口

# kubectl edit svc prometheus-k8s -n monitoring
service/prometheus-k8s edited
# kubectl edit svc grafana -n monitoring
service/grafana edited
# kubectl edit svc alertmanager-main -n monitoring
service/alertmanager-main edited
# kubectl get svc -n monitoring | grep NodePort
alertmanager-main       NodePort    10.97.155.71            9093:30093/TCP               21h
grafana                 NodePort    10.110.28.251           3000:30030/TCP               21h
prometheus-k8s          NodePort    10.109.3.70             9090:30090/TCP               21h

7.访问测试
K8S实践Ⅸ(集群监控)

三、配置

1.查看prometheus的targets页面

K8S实践Ⅸ(集群监控)

发现kube-controller-manager 和 kube-scheduler 这两个系统组件没有监控到,此处和ServiceMonitor 的定义有关系

# cat prometheus/prometheus-serviceMonitorKubeScheduler.yaml
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  labels:
    k8s-app: kube-scheduler
  name: kube-scheduler
  namespace: monitoring
spec:
  endpoints:
  - interval: 30s
    port: http-metrics
  jobLabel: k8s-app
  namespaceSelector:
    matchNames:
    - kube-system
  selector:
    matchLabels:
      k8s-app: kube-scheduler

selector.matchLabels在kube-system这个命名空间下面匹配具有k8s-app=kube-scheduler这样的Service,但是系统中没有对应的Service。

2.创建kube-controller-manager 和 kube-scheduler对应的Service

# cat cms-svc.yaml 
apiVersion: v1
kind: Service
metadata:
  namespace: kube-system
  name: kube-controller-manager
  labels:
    k8s-app: kube-controller-manager
spec:
  selector:
    component: kube-controller-manager
  ports:
  - name: http-metrics
    port: 10252
    targetPort: 10252
    protocol: TCP
---
apiVersion: v1
kind: Service
metadata:
  namespace: kube-system
  name: kube-scheduler
  labels:
    k8s-app: kube-scheduler
spec:
  selector:
    component: kube-scheduler
  ports:
  - name: http-metrics
    port: 10251
    targetPort: 10251
    protocol: TCP
# kubectl describe pod kube-controller-manager-k8s-master01 -n kube-system
Labels:               component=kube-controller-manager
                      tier=control-plane

3.查看kube-controller-manager 和 kube-scheduler是否正常

K8S实践Ⅸ(集群监控)

4.访问Grafana

K8S实践Ⅸ(集群监控)

相关内容

热门资讯

台电换新Logo六个字花近百万... 日前,台电弃用了沿用80年、由“当代草圣”于右任题写的招牌Logo字体,花了近百万(新台币,下同)设...
“百度AI称一律师被判刑”构成... 澎湃新闻记者 谭君江苏南京执业律师李小亮发现,在百度手机 APP、百度网站搜索其个人姓名+职务时,百...
DeepSeek被曝狂融500... 潮新闻客户端 记者 张云山 据外媒The Information报道,中国人工智能明星公司DeepS...
问一问局部装修, 可以直接通过装修公司预约局部装修,也可以直接在齐家网预约局部装修风服务,大家可以先留下个人的姓名和所...
乳胶漆要刷几遍,间隔时间 1、乳胶漆可以喷涂2~3遍,也可以喷涂4遍。如果是夏天,一般需要1到2个小时,秋冬季需要4个小时以上...
理发店墙面刷什么颜色比较好 1、一般需要根据理发店的装修风格来选择乳胶漆的颜色,如果装修风格偏向古典风格,可以选择颜色深一点的颜...
卫生间墙面刷什么漆可以防水 卫生间墙面最好刷低水溶性涂料。这种涂料的优点在于易于施工、成本低、施工方便、无毒,耐油、耐碱、可以用...
原创 入... vivoS30最让人眼前一亮的是两款“甜酷碰撞”配色:粉色或黄色底色与黑色中框的拼接,打破了传统配色...
墙面刷乳胶漆几遍好 乳胶漆一般需要三遍,首先第1遍的时候要使用浓度比较高的乳胶漆,浅浅的一层即可,等待干燥之后涂抹第2遍...
俄乌同意延长停火,泽连斯基签令... 据凤凰卫视报道,俄罗斯总统助理乌沙科夫5月8日表示,俄方同意美国总统特朗普提出的“将俄乌停火延长至5...