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实践Ⅸ(集群监控)

相关内容

热门资讯

玩家分享攻略“哪吒重生.开挂器... 玩家分享攻略“哪吒重生.开挂器?”外卦神器下载您好,哪吒重生这个游戏其实有挂的,确实是有挂的,需要了...
【第一资讯】“乐享牛牛.怎么装... 您好:乐享牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
终于懂了“一喜棋牌.是不是有挂... 您好:一喜棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
今日重磅消息“阿道夫十三水.辅... 今日重磅消息“阿道夫十三水.辅助开挂神器?”确实真的有挂您好,阿道夫十三水这个游戏其实有挂的,确实是...
今日重磅消息“全民游戏.到底是... 有 亲,根据资深记者爆料全民游戏是可以开挂的,确实有挂(咨询软件无需打开...
最新引进“全民如意麻将.开挂神... 家人们!今天小编来为大家解答全民如意麻将透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里...
玩家最新攻略“决战卡五星.辅助... 您好:决战卡五星这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
终于了解“先锋大厅.有挂吗?”... 终于了解“先锋大厅.有挂吗?”必胜开挂神器您好,先锋大厅这个游戏其实有挂的,确实是有挂的,需要了解加...
【第一财经】“微乐安庆麻将.究... 网上科普关于“微乐安庆麻将有没有挂”话题很是火热,小编也是针对微乐安庆麻将作*弊开挂的方法以及开挂对...
终于了解“蜀山四川麻将.是不是... 终于了解“蜀山四川麻将.是不是有挂?”透视曝光猫腻您好,蜀山四川麻将这个游戏其实有挂的,确实是有挂的...