How to Deploy Grafana on Kubernetes

How to Deploy Grafana on Kubernetes

This guide walks you through the deployment of Grafana, a powerful monitoring and visualization tool, on a Kubernetes cluster. It includes setting up a custom configuration and persistent storage to ensure data retention across restarts.

Prerequisites

  1. Kubernetes Cluster: A running Kubernetes cluster with kubectl configured.
  2. Storage: Ensure a PersistentVolume (PV) or provisioner is available in your cluster for persistent storage.

Namespace: Create a monitoring namespace for Grafana:

kubectl create namespace monitoring

Step 1: Configure Grafana

Create a ConfigMap to store Grafana’s configuration. The configuration below enables anonymous access, embedding of dashboards, and sets default admin credentials.

ConfigMap

apiVersion: v1
kind: ConfigMap
metadata:
  name: grafana-config
  namespace: monitoring
data:
  grafana.ini: |
    [server]
    root_url = http://IP:3000
    domain = IP

    [security]
    allow_embedding = true
    admin_user = admin
    admin_password = admin	    

    [auth.anonymous]
    enabled = true
    org_name = Main Org.
    org_role = Viewer

Apply the ConfigMap:

kubectl apply -f grafana-config.yaml

Step 2: Deploy Grafana

Create a Deployment for Grafana. This deployment uses the latest Grafana image and mounts both a ConfigMap for custom configurations and a PersistentVolumeClaim (PVC) for storage.

Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: grafana
  namespace: monitoring
spec:
  replicas: 1
  selector:
    matchLabels:
      app: grafana
  template:
    metadata:
      labels:
        app: grafana
    spec:
      containers:
      - name: grafana
        image: grafana/grafana:latest
        ports:
        - containerPort: 3000
        volumeMounts:
        - name: grafana-storage
          mountPath: /var/lib/grafana
        - name: grafana-config
          mountPath: /etc/grafana/grafana.ini
          subPath: grafana.ini
      volumes:
      - name: grafana-storage
        persistentVolumeClaim:
          claimName: grafana-storage
      - name: grafana-config
        configMap:
          name: grafana-config

Apply the Deployment:

kubectl apply -f grafana-deployment.yaml

Step 3: Configure Persistent Storage

Create a PersistentVolumeClaim (PVC) to provide persistent storage for Grafana. This ensures that dashboards, users, and other settings persist across pod restarts.

PersistentVolumeClaim

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: grafana-storage
  namespace: monitoring
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 5Gi

Apply the PVC:

kubectl apply -f grafana-pvc.yaml

Step 4: Expose Grafana

Create a Service to expose Grafana outside the cluster. Using a LoadBalancer service type ensures external access to the Grafana interface.

Service

apiVersion: v1
kind: Service
metadata:
  name: grafana
  namespace: monitoring
spec:
  type: LoadBalancer
  ports:
  - port: 3000
    targetPort: 3000
    protocol: TCP
  selector:
    app: grafana

Apply the Service:

kubectl apply -f grafana-service.yaml

Step 5: Access Grafana

  1. Open your browser and navigate to http://<EXTERNAL-IP>:3000.
  2. Log in with the default credentials (admin/admin) or those defined in the ConfigMap.

After deploying the Service, check the external IP:

kubectl get svc -n monitoring

Note the EXTERNAL-IP under the grafana service.


以上資訊來自ChatGPT的整理

Read more

如何安裝 KubeSphere 以及管理 Workspace 和新增 Label

前言 在 Kubernetes 的世界中,KubeSphere 是一個功能強大的開源容器平台,它不僅讓 Kubernetes 的管理更簡單,還集成了多集群管理、DevOps、微服務治理等功能。本篇文章將教您如何使用 Helm 快速安裝 KubeSphere,並如何通過管理 Workspace 和新增 Label 來實現資源的高效管理。 一、使用 Helm 安裝 KubeSphere 1. 為什麼選擇 Helm 安裝? Helm 是 Kubernetes 中廣泛使用的包管理工具,使用 Helm 安裝 KubeSphere 有以下優點: * 自動化:簡化安裝過程,減少手動配置。 * 靈活性:可以根據需求自定義安裝的模組。 * 版本控制:支持管理和回滾安裝的不同版本。 2. 安裝前準備 在開始安裝之前,請確保以下條件:

By Tim Chiagn

我的經驗

1. 網絡與安全 (Networking & Security) * Fortigate: 防火牆來管理網路環境 * Traefik: 用於 K8s 的 2. 虛擬化與存儲 (Virtualization & Storage) * Esxi: 買了一台server 使用 Esxi 管理 vm * TrueNAS: 還沒有買 NAS 使用這個加減用一下 3. DevOps 與持續交付 (DevOps & CI/CD) * ArgoCD: GitOps 工具,用於 Kubernetes 的應用交付和管理,支持自動化部署和同步。 * KubeSphere:提供完整的 CI/CD 工作流管理、應用部署和 DevOps 整合功能,是 Kubernetes

By Tim Chiagn