Kubernetes实录-第一篇-集群部署配置(33) Kubernetes监控方案-使用prometheus实现全栈监控(4)-监控可视化工具grafana配置

Kubernetes实录系列记录文档完整目录参考: Kubernetes实录-目录

相关记录链接地址 :

前面的几篇记录(15/16/17)记录了kubernetes使用prometheus作为监控方案的场景,架构,各种exporter配置以及prometheus的集成部署配置。本篇记录可视化工具Grafana在kubernetes监控方案中的集成。
备注:grafana的介绍可以参考grafana官方文档

一、kubernetes集成部署grafana

1.1 grafana定义文件

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: monitoring-grafana
  namespace: kube-system
spec:
  replicas: 1
  template:
    metadata:
      labels:
        task: monitoring
        k8s-app: grafana
    spec:
      containers:
      - name: grafana
        image: grafana/grafana:5.0.4
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 3000
          protocol: TCP
        volumeMounts:
        - mountPath: /var
          name: grafana-storage
        env:
        - name: INFLUXDB_HOST
          value: monitoring-influxdb
        - name: GF_SERVER_HTTP_PORT
          value: "3000"
          # The following env variables are required to make Grafana accessible via
          # the kubernetes api-server proxy. On production clusters, we recommend
          # removing these env variables, setup auth for grafana, and expose the grafana
          # service using a LoadBalancer or a public IP.
        - name: GF_AUTH_BASIC_ENABLED
          value: "false"
        - name: GF_AUTH_ANONYMOUS_ENABLED
          value: "true"
        - name: GF_AUTH_ANONYMOUS_ORG_ROLE
          value: Admin
        - name: GF_SERVER_ROOT_URL
          # If you're only using the API Server proxy, set this value instead:
          # value: /api/v1/namespaces/kube-system/services/monitoring-grafana/proxy
          value: /
      volumes:
      - name: grafana-storage
        emptyDir: {}
      tolerations:
      - key: node-role.kubernetes.io/master
        value: ""
        effect: NoSchedule
      nodeSelector:
        node-role.kubernetes.io/master: ""
---
apiVersion: v1
kind: Service
metadata:
  name: monitoring-grafana
  namespace: kube-system
  annotations:
    prometheus.io/scrape: 'true'
    prometheus.io/tcp-probe: 'true'
    prometheus.io/tcp-probe-port: '80'
  labels:
    # For use as a Cluster add-on (https://github.com/kubernetes/kubernetes/tree/master/cluster/addons)
    # If you are NOT using this as an addon, you should comment out this line.
    #kubernetes.io/cluster-service: 'true'
    #kubernetes.io/name: monitoring-grafana
spec:
  # type: NodePort
  # In a production setup, we recommend accessing Grafana through an external Loadbalancer
  # or through a public IP.
  # type: LoadBalancer
  # You could also use NodePort to expose the service at a randomly-generated port
  # type: NodePort
  #type: ClusterIP
  selector:
    k8s-app: grafana
  ports:
    - name: grafana
      port: 80
      targetPort: 3000


---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: monitoring-grafana
  namespace: kube-system
spec:
  rules:
  - host: grafana.ejuops.com
    http:
      paths:
      - path: /
        backend:
          serviceName: monitoring-grafana
          servicePort: grafana

1.2 部署grafana

反向代理使用traefik,域名使用grafana.ejuops.com(非真域名,需要配置hosts访问)

kubectl apply -f grafana-deployment.yaml 
	deployment.extensions/monitoring-grafana created
	service/monitoring-grafana created
	ingress.extensions/monitoring-grafana created

kubectl get -f grafana-deployment.yaml 
	NAME                                       READY   UP-TO-DATE   AVAILABLE   AGE
	deployment.extensions/monitoring-grafana   1/1     1            1           5m
	
	NAME                         TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)   AGE
	service/monitoring-grafana   ClusterIP   10.99.65.209   <none>        80/TCP    5m
	
	NAME                                    HOSTS                 ADDRESS   PORTS   AGE
	ingress.extensions/monitoring-grafana   grafana.ejuops.com             80      6d

1.3 访问grafana

配置hosts文件(假域名访问grafana.ejuops.com)

C:\Windows\System32\drivers\etc\hosts
10.99.12.201 grafana.ejuops.com

二、grafana配置

2.1 配置数据源为前面章节配置好的prometheus服务

参数项类型备注
namekubernetes-prometheus字符串
TypePrometheus下拉选择项
URLhttp://prometheus.ejuops.com访问地址
Accessdirect下拉选择项

在这里插入图片描述

2.2 配置dashboard

grafana的dashboard可以根据需求自定义,也可以导入(import)官方已经配置好的模板,直接输入需要import的模板号。
更多模板可以去grafana模板市场去查 https://grafana.com/dashboards?search=kubernetes

模板号描述备注
315,1621cadvisor采集的各种指标的图表二选一
1860node-exporter采集的各种主机相关的指标的图表
6417kube-state-metrics采集的各种k8s资源对象的状态的图表
4859,4865blackbox-exporter采集的服务的http状态指标的图表二选一
8588Kubernetes Deployment Statefulset Daemonset metrics
5345blackbox-exporter采集的服务的网络状态指标的图表
  • 第一步: 选择New dashboard,import dashboard
    在这里插入图片描述
  • 第二步,根据模板号查询,导入模板,例如315
    在这里插入图片描述
  • 第三步,显示效果(模板号315)
    在这里插入图片描述
    其他模板的显示这里就不展示了。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值