文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

掌握 Kubernetes 集群 Etcd 数据备份与快速恢复方法

2024-11-29 22:22

关注

Kubernetes etcd 备份使用etcdctl

以下是您应该了解的有关 etcd 备份的信息:

按照下面给出的步骤备份 etcd 快照:

(1) 登录到控制平面

(2) 如果群集控制平面中没有 etcdctl,请使用以下命令进行安装。

sudo apt install etcd-client

(3) 我们需要将以下三部分信息传递给etcdctl以获取etcd快照。

你可以通过两种方式获得上述参数:

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= \
  --cert= \
  --key= \
  snapshot save 

添加实际位置和参数时,命令如下所示。执行该命令进行备份。您可以将/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 

让我们执行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备份和恢复。

来源:攻城狮成长日记内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯