【ETCD】【实操篇(十四)】etcd 集群备份与还原指南

devtools/2024/12/29 16:57:53/

在这里插入图片描述

etcd 是一个高可用的分布式键值存储,常用于分布式系统的配置共享和服务注册。本文将基于提供的启动脚本,详细讲解如何对 etcd 集群进行数据的备份与还原。

目录

    • 一、启动 etcd 集群
    • 二、备份 etcd 数据
      • 1. 使用 etcdctl 保存快照
      • 2. 验证快照文件
    • 三、还原 etcd 数据
      • 1. 使用 etcdutl 恢复快照
      • 2. 使用新数据目录启动集群
      • 3. 验证恢复后的集群
    • 四、注意事项
    • 五、总结

etcd__5">一、启动 etcd 集群

以下是用于启动一个三节点 etcd 集群的脚本:

@echo off
REM 设置通用参数
set TOKEN=token-01
set CLUSTER_STATE=new
set NAME_1=machine-1
set NAME_2=machine-2
set NAME_3=machine-3
set HOST_1=127.0.0.1
set HOST_2=127.0.0.1
set HOST_3=127.0.0.1
set PEER_PORT_1=2380
set PEER_PORT_2=2381
set PEER_PORT_3=2382
set CLIENT_PORT_1=2379
set CLIENT_PORT_2=2383
set CLIENT_PORT_3=2384
set CLUSTER=%NAME_1%=http://%HOST_1%:%PEER_PORT_1%,%NAME_2%=http://%HOST_2%:%PEER_PORT_2%,%NAME_3%=http://%HOST_3%:%PEER_PORT_3%REM 创建目录存储 etcd 数据
mkdir data.etcd1
mkdir data.etcd2
mkdir data.etcd3REM 启动第一个 etcd 实例
start etcd.exe --data-dir=data.etcd1 --name %NAME_1% ^--initial-advertise-peer-urls http://%HOST_1%:%PEER_PORT_1% --listen-peer-urls http://%HOST_1%:%PEER_PORT_1% ^--advertise-client-urls http://%HOST_1%:%CLIENT_PORT_1% --listen-client-urls http://%HOST_1%:%CLIENT_PORT_1% ^--initial-cluster %CLUSTER% ^--initial-cluster-state %CLUSTER_STATE% --initial-cluster-token %TOKEN% ^--log-level debugREM 启动第二个 etcd 实例
start etcd.exe --data-dir=data.etcd2 --name %NAME_2% ^--initial-advertise-peer-urls http://%HOST_2%:%PEER_PORT_2% --listen-peer-urls http://%HOST_2%:%PEER_PORT_2% ^--advertise-client-urls http://%HOST_2%:%CLIENT_PORT_2% --listen-client-urls http://%HOST_2%:%CLIENT_PORT_2% ^--initial-cluster %CLUSTER% ^--initial-cluster-state %CLUSTER_STATE% --initial-cluster-token %TOKEN% ^--log-level debugREM 启动第三个 etcd 实例
start etcd.exe --data-dir=data.etcd3 --name %NAME_3% ^--initial-advertise-peer-urls http://%HOST_3%:%PEER_PORT_3% --listen-peer-urls http://%HOST_3%:%PEER_PORT_3% ^--advertise-client-urls http://%HOST_3%:%CLIENT_PORT_3% --listen-client-urls http://%HOST_3%:%CLIENT_PORT_3% ^--initial-cluster %CLUSTER% ^--initial-cluster-state %CLUSTER_STATE% --initial-cluster-token %TOKEN% ^--log-level debugecho All etcd instances started with debug logging. Press any key to exit...
pause

执行此脚本后,etcd 集群的三个节点将在本地启动,分别监听不同的客户端和对等通信端口。

etcd__63">二、备份 etcd 数据

备份是保障数据安全的重要步骤。以下是备份 etcd 集群数据的操作步骤:

etcdctl__67">1. 使用 etcdctl 保存快照

确保 etcdctl 已正确配置,执行以下命令保存当前集群数据的快照:

etcdctl snapshot save snapshot.db

成功执行后,将生成一个名为 snapshot.db 的快照文件。

2. 验证快照文件

为了确保快照文件的完整性,可以通过以下命令验证:

etcdctl snapshot status snapshot.db

该命令将输出快照的元数据,如版本信息、数据大小等。

etcd__87">三、还原 etcd 数据

还原是将快照文件中的数据恢复到新的 etcd 集群中。以下是具体步骤:

etcdutl__91">1. 使用 etcdutl 恢复快照

使用 etcdctl 工具将快照文件还原到新的数据目录:

etcdctl snapshot restore db   --name m1 --initial-cluster m1=http://127.0.0.1:2380,m2=http://127.0.0.1:2381,m3=http://127.0.0.1:2382  --initial-cluster-token etcd-cluster-1  --initial-advertise-peer-urls http://127.0.0.1:2380etcdctl snapshot restore db --name m2 --initial-cluster m1=http://127.0.0.1:2380,m2=http://127.0.0.1:2381,m3=http://127.0.0.1:2382 --initial-cluster-token etcd-cluster-1 --initial-advertise-peer-urls http://127.0.0.1:2381etcdutl snapshot restore db --name m3 --initial-cluster m1=http://127.0.0.1:2380,m2=http://127.0.0.1:2381,m3=http://127.0.0.1:2382 --initial-cluster-token etcd-cluster-1 --initial-advertise-peer-urls http://127.0.0.1:2382

每个命令都会为对应节点创建一个新的数据目录,例如 m1.etcdm2.etcdm3.etcd

2. 使用新数据目录启动集群

使用还原后的数据目录重新启动 etcd 集群:

etcd --name m1 \--data-dir m1.etcd--listen-client-urls http://127.0.0.1:2379 \--advertise-client-urls http://127.0.0.1:2379 \--listen-peer-urls http://127.0.0.1:2380 &etcd --name m2 \--data-dir m2.etcd \--listen-client-urls http://127.0.0.1:2383 \--advertise-client-urls http://127.0.0.1:2383 \--listen-peer-urls http://127.0.0.1:2381 &etcd --name m3 \--data-dir m3.etcd--listen-client-urls http://127.0.0.1:2384 \--advertise-client-urls http://127.0.0.1:2384 \--listen-peer-urls http://127.0.0.1:2382 &

3. 验证恢复后的集群

确保集群启动成功后,可以通过以下命令检查节点状态:

etcdctl endpoint status --cluster

输出应包含所有节点的健康状态和元数据,表明集群已成功恢复。

四、注意事项

  1. 备份频率:根据业务需要,定期执行快照备份,确保数据安全。
  2. 权限配置:备份与还原操作需具有相应权限,避免数据泄露。
  3. 版本兼容性:确保 etcdctl、etcdutl 与 etcd 集群的版本一致。
  4. 测试还原:在生产环境中使用前,建议在测试环境中验证备份与还原流程。

五、总结

本文基于启动脚本,详细讲解了 etcd 集群的备份与还原操作。通过备份,保障数据的持久性与安全性;通过还原,快速恢复数据并确保业务连续性。


http://www.ppmy.cn/devtools/146082.html

相关文章

SQL 表连接操作

SQL 表连接操作是数据库查询中一个非常重要的概念,它允许从多个表中检索相关数据。表连接的主要类型包括 INNER JOIN、LEFT JOIN(或 LEFT OUTER JOIN)、RIGHT JOIN(或 RIGHT OUTER JOIN)、FULL JOIN(或 FULL OUTER JOIN)以及 CROSS JOIN。下面是详细解释每种连接操作…

将 ASP.NET Core 应用程序的日志保存到 D 盘的文件中 (如 Serilog)

将 ASP.NET Core 应用程序的日志保存到 D 盘的文件中,可以使用第三方日志库(如 Serilog)来实现。Serilog 是一个流行的日志库,支持将日志输出到文件、控制台、数据库等多种目标。 以下是实现步骤: 1. 安装 Serilog 相…

智慧城市可以实现哪些方面的监测

智慧城市通过集成物联网、大数据、云计算、人工智能等前沿技术,实现了对城市运行状态的全面、实时、精准的监测。这种监测覆盖了城市的多个关键领域,为城市管理提供了强有力的数据支持,推动了城市的可持续发展和居民生活质量的提升。以下是对…

模方要使用多机引擎,有什么要求

1.多台机器需要在同一个局域网下,并且其他机器也安装了模方软件 2.工程放在网络路径,此时任务路径默认是网络路径,不建议修改 3.数据存在网络路径,包括新建工程时添加的 osgb、obj、空三文件,匀色需要使用多机的话也…

gcc和g++的联系和区别

1. GCC 和 G 的全称 GCC: GNU Compiler Collection 它是一个完整的编译器集合,支持多种编程语言(包括 C、C、Fortran、Go、Ada 等)。当使用 gcc 命令时,默认将其视为 GNU C 编译器,但它同样可以编译 C 程序&#xff08…

Airwallex空中云汇实现独立站安全高效收款

在数字化浪潮的强劲推动下,全球贸易正加快迈向数字化转型,其中跨境电商已深度融入国际贸易体系,成为促进全球经济互联互通的重要力量。 而独立站在这一领域中扮演着 举足轻重的角色,吸引了越来越多的商家投身于其建设之中&#xf…

deepin 安装 zookeeper

deepin 安装 zookeeper 1、升级软件 sudo apt updatesudo apt -y dist-upgrade2、安装常用软件 sudo apt -y install gcc make openssl libssl-dev libpcre3 libpcre3-dev libgd-dev \rsync openssh-server vim man zip unzip net-tools tcpdump lrzsz tar wget3、开启ssh …

2022年国家公考《申论》题(行政执法)

2022年国家公考《申论》题(行政执法) 材料一 新型冠状病毒肺炎疫情发生后,党中央、国务院出台了一系列支持企业发展的惠企政策。N市积极落实各项惠企政策,不断优化营商环境,推动区域经济高质量跨越式发展。   “当时…