成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

掌握 Kubernetes 集群 Etcd 數據備份與快速恢復方法

云計算 云原生
在本教程中,您將學習如何在 Kubernetes 集群上使用 etcd 快照進行 etcd 備份和恢復。

在Kubernetes架構中,etcd是集群的重要組成部分。所有集群對象及其狀態都存儲在etcd中。為了更好地理解Kubernetes,有幾點關于etcd的信息是您需要了解的。

  • 它是一個一致的、分布式的、安全的鍵值存儲。
  • 它使用raft協議。
  • 支持堆疊etcd的高可用架構。
  • 它存儲kubernetes集群配置、所有API對象、對象狀態和服務發現細節。

Kubernetes etcd 備份使用etcdctl

以下是您應該了解的有關 etcd 備份的信息:

  • etcd 有一個內置的快照機制。
  • etcdctl是與 etcd 交互以獲取快照的命令行實用程序。

按照下面給出的步驟備份 etcd 快照:

(1) 登錄到控制平面

(2) 如果群集控制平面中沒有 etcdctl,請使用以下命令進行安裝。

sudo apt install etcd-client

(3) 我們需要將以下三部分信息傳遞給etcdctl以獲取etcd快照。

  • etcd endpoint (–endpoints)
  • ca certificate (–cacert)
  • server certificate (–cert)
  • server key (–key)

你可以通過兩種方式獲得上述參數:

  • etcd的靜態pod清單文件位于/etc/kubernetes/manifest/etcd.yaml位置。

  • 您也可以通過描述在kube-system命名空間中運行的etcd pod來獲得上述細節。在描述pod時,將etcd-master-node替換為您的etcd pod名稱。
kubectl get po -n kube-system
kubectl describe pod etcd-master-node -n kube-system

(4) 使用以下命令進行etcd快照備份。

ETCDCTL_API=3 etcdctl \
  --endpoints=https://127.0.0.1:2379 \
  --cacert=<ca-file> \
  --cert=<cert-file> \
  --key=<key-file> \
  snapshot save <backup-file-location>

添加實際位置和參數時,命令如下所示。執行該命令進行備份。您可以將/opt/backup/etc.db替換為您選擇的位置和名稱。

ETCDCTL_API=3 etcdctl \
  --endpoints=https://127.0.0.1:2379 \
  --cacert=/etc/kubernetes/pki/etcd/ca.crt \
  --cert=/etc/kubernetes/pki/etcd/server.crt \
  --key=/etc/kubernetes/pki/etcd/server.key \
  snapshot save /opt/backup/etcd.db

如果執行成功,你會得到一個“Snapshot saved at /opt/backup/etc.db”的消息,如下所示。

此外,您可以使用以下命令來驗證快照。

ETCDCTL_API=3 etcdctl --write-out=table snapshot status /opt/backup/etcd.db

下面是一個示例輸出。

+----------+----------+------------+------------+
|   HASH   | REVISION | TOTAL KEYS | TOTAL SIZE |
+----------+----------+------------+------------+
| b7147656 |    51465 |       1099 |     5.1 MB |
+----------+----------+------------+------------+

Kubernetes etcd恢復使用快照備份

現在我們在/opt/backup/etc.db位置有了備份。我們將使用快照備份來恢復etcd。

下面是恢復etcd的命令:

ETCDCTL_API=3 etcdctl snapshot restore <backup-file-location>

讓我們執行etcd還原命令。/opt/backup/etc.db是備份文件:

ETCDCTL_API=3 etcdctl snapshot restore /opt/backup/etcd.db

如果您想使用特定的數據目錄進行恢復,可以使用--data-dir標志添加位置,如下所示:

ETCDCTL_API=3 etcdctl --data-dir /opt/etcd snapshot restore /opt/backup/etcd.db

創建定時任務備份

通過配置 Kubernetes CronJob,可以指定定期執行備份任務的時間表,確保etcd數據在指定的時間間隔內自動備份。這種方式不僅簡化了備份流程,還能確保集群數據的安全和持久性,防止數據丟失。CronJob的靈活性和自動化特性使得管理和維護etcd備份變得更加高效和可靠。

apiVersion:batch/v1
kind:CronJob
metadata:
  name:etcd-disaster-recovery# 定義 CronJob 的名稱
  namespace:cronjob# 指定 CronJob 所屬的命名空間
spec:
  schedule:"0 2 * * *"# 設置定時任務的調度時間表達式,表示每天凌晨2點執行一次
  jobTemplate:
    spec:
      template:
        metadata:
          # labels:
          #   app: etcd-disaster-recovery  # 為 Pod 添加標簽,可根據需要注釋或刪除
        spec:
          affinity:# 定義 Pod 的親和性配置
            nodeAffinity:
              requiredDuringSchedulingIgnoredDuringExecution:
                nodeSelectorTerms:
                -matchExpressions:
                  -key:kubernetes.io/hostname
                    operator:In
                    values:
                    -master01# 選擇特定的節點(這里是選擇 hostname 為 master01 的節點)
          containers:# 定義 Pod 中的容器
          -name:etcd# 容器名稱
            image:registry.k8s.io/etcd:3.5.10-0# 使用的 etcd 鏡像版本為 3.5.10-0
            imagePullPolicy:"IfNotPresent"# 鏡像拉取策略,如果本地已存在該鏡像,則不重新拉取
            command:# 容器啟動命令
            -sh
            --c
            -"export ETCDCTL_API=3; \
               etcdctl --endpoints=$ENDPOINT \
               --cert=/etc/kubernetes/pki/etcd/server.crt \
               --key=/etc/kubernetes/pki/etcd/server.key \
               --cacert=/etc/kubernetes/pki/etcd/ca.crt \
               snapshot save /snapshot/snapshot.db; \
               echo etcd backup success"
            env:# 環境變量配置,設置了一個名為 ENDPOINT 的環境變量,值為 "https://127.0.0.1:2379"
            -name:ENDPOINT
              value:"https://127.0.0.1:2379"
            volumeMounts:# 掛載配置,指定了容器中需要掛載的卷和掛載路徑
            -mountPath:"/etc/kubernetes/pki/etcd"# 將主機上的 /etc/kubernetes/pki/etcd 目錄掛載到容器的 /etc/kubernetes/pki/etcd 路徑
              name:etcd-certs
            -mountPath:"/var/lib/etcd"# 將主機上的 /var/lib/etcd 目錄掛載到容器的 /var/lib/etcd 路徑
              name:etcd-data
            -mountPath:"/snapshot"# 將主機上的 /root/etcd/snapshot 目錄掛載到容器的 /snapshot 路徑
              name:snapshot
              subPath:data/etcd-snapshot# 在主機上的 /root/etcd/snapshot 目錄下,將數據掛載到容器的 /snapshot/data/etcd-snapshot 路徑下
            -mountPath:/etc/localtime# 將主機上的 /etc/localtime 文件掛載到容器的 /etc/localtime 路徑
              name:lt-config
            -mountPath:/etc/timezone# 將主機上的 /etc/timezone 文件掛載到容器的 /etc/timezone 路徑
              name:tz-config
          restartPolicy:OnFailure# 定義容器重啟策略,當容器失敗時才會重啟
          volumes:# 卷配置,定義了 Pod 中使用的卷
          -name:etcd-certs
            hostPath:
              path:/etc/kubernetes/pki/etcd# 使用主機上的 /etc/kubernetes/pki/etcd 目錄作為卷
          -name:etcd-data
            hostPath:
              path:/var/lib/etcd# 使用主機上的 /var/lib/etcd 目錄作為卷
          -name:snapshot
            hostPath:
              path:/root/etcd/snapshot# 使用主機上的 /root/etcd/snapshot 目錄作為卷
          -name:lt-config
            hostPath:
              path:/etc/localtime# 使用主機上的 /etc/localtime 文件作為卷
          -name:tz-config
            hostPath:
              path:/etc/timezone# 使用主機上的 /etc/timezone 文件作為卷
        hostNetwork:true# 使用主機網絡模式,Pod 將共享主機的網絡命名空間

結論

在這篇博客中,我們學習了使用etcdctl命令行實用工具進行Kubernetes etcd備份和恢復。

責任編輯:趙寧寧 來源: 攻城獅成長日記
相關推薦

2022-08-05 08:48:33

KubernetesEtcd數據

2009-04-10 01:46:41

2011-08-02 16:03:47

Oracle數據庫冷備份冷備份異地恢復

2011-02-28 13:31:17

Oracle數據庫

2025-04-22 09:40:24

2020-07-23 19:42:12

MySQL備份恢復數據庫

2011-05-13 13:15:52

SYBASE ASA數

2021-11-26 11:10:40

Kubernetes容器存儲命令

2019-07-04 13:10:53

Docker設計云計算

2010-05-04 09:36:02

Unix文件

2011-04-12 15:44:08

Oracle數據庫

2024-02-28 10:23:18

etcd數據庫Kubernetes

2013-05-16 15:12:47

在線備份快照備份

2023-06-27 17:37:08

Kubernete容器集群

2024-04-18 09:20:43

PostgreSQL關系型數據庫數據庫管理系統

2016-10-13 09:14:03

大數據備份

2010-07-02 09:36:30

SQL Server

2021-12-03 11:06:01

VeleroKubernetesLinux

2010-07-19 15:21:03

Win2000 Tel

2023-11-26 13:36:20

協議Raft
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲第一天堂 | 久久精品手机视频 | 亚洲综合天堂网 | 国产毛片av | 免费成人高清在线视频 | 久久久久成人精品 | 亚洲乱码一区二区三区在线观看 | 日韩有码在线观看 | 亚洲欧美在线视频 | 亚洲伊人精品酒店 | 91av小视频| 国产成人av在线播放 | 影音先锋中文字幕在线观看 | 最新免费黄色网址 | 久久免费视频观看 | 国产精品久久久久久久午夜 | 中文字幕av亚洲精品一部二部 | 国产一区不卡 | 精品视频一区二区 | 亚洲精品一区二区三区蜜桃久 | 国产中文字幕在线观看 | 久久青青| 午夜精品久久久 | 亚洲欧美网站 | 精品成人一区二区 | 中文字幕在线观看av | 完全免费在线视频 | 91精品久久久久久久久 | 综合一区二区三区 | 国产精品国产精品国产专区不蜜 | 黄色网址在线播放 | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 91麻豆精品国产91久久久久久 | 欧美精品一区二区三区在线 | 成人午夜电影网 | 精品91久久久 | 久久精品中文字幕 | av色站| 91久久国产综合久久 | 免费观看毛片 | 日韩久久综合网 |