Etcd备份及恢复

一、Etcd数据备份

1、备份命令

复制代码
[root@localhost ~]# export ETCDCTL_API=3
[root@localhost ~]# /data/etcd-3.4.9/bin/etcdctl --endpoints=10.2.20.108:2379 snapshot save etcd-`date "+%Y-%m-%d_%H-%M-%S"`.snapshot

2、备份完成后会在当前目录生成备份文件

复制代码
[root@localhost ~]# ls
anaconda-ks.cfg  etcd-2023-08-17_16-43-08.snapshot  etcd-3.4.9.tar.gz

二、数据恢复

etcd集群中所有实例,可通过随意一台etcd的备份文件进行恢复,数据是一样的。

备份恢复命令模版

ETCDCTL_API=3 etcdctl snapshot restore +备份文件名 \

--name \ #当前实例在集群中的名字

--initial-cluster \ #集群中所有实例通讯地址。

--initial-cluster-token etcd-cluster \ #集群名字,不要与已有集群冲突

--initial-advertise-peer-urls \ #当前实例进群通讯地址

--data-dir /data/mydata_etcd_3.4.9 #数据恢复目录

1、实例1恢复

复制代码
$ ETCDCTL_API=3 etcdctl snapshot restore etcd-2023-08-17_16-43-08.snapshot \
  --name etcd-201 \
  --initial-cluster etcd-201=http://10.2.20.77:2380,etcd-202=http://10.2.20.88:2380,etcd-203=http://10.2.20.99:2380 \
  --initial-cluster-token etcd-cluster \
  --initial-advertise-peer-urls http://10.2.20.77:2380 \
  --data-dir /data/mydata_etcd_3.4.9

2、实例2恢复

复制代码
$ ETCDCTL_API=3 etcdctl snapshot restore etcd-2023-08-17_16-43-08.snapshot \
  --name etcd-202 \
  --initial-cluster etcd-201=http://10.2.20.77:2380,etcd-202=http://10.2.20.88:2380,etcd-203=http://10.2.20.99:2380 \
  --initial-cluster-token etcd-cluster \
  --initial-advertise-peer-urls http://10.2.20.88:2380 \
  --data-dir /data/mydata_etcd_3.4.9

3、实例3恢复

复制代码
$ ETCDCTL_API=3 etcdctl snapshot restore etcd-2023-08-17_16-43-08.snapshot \
  --name etcd-203 \
  --initial-cluster etcd-201=http://10.2.20.77:2380,etcd-202=http://10.2.20.88:2380,etcd-203=http://10.2.20.99:2380 \
  --initial-cluster-token etcd-cluster \
  --initial-advertise-peer-urls http://10.2.20.99:2380 \
  --data-dir /data/mydata_etcd_3.4.9

4、启动恢复后的集群

复制代码
systemctl daemon-reload
systemctl start etcd

5、检查新进群

复制代码
查看leader是否选举成功

[root@etcd003 ~]# ETCDCTL_API=3 /data/hxsd-etcd-3.4.9/bin/etcdctl  --endpoints="http://10.2.20.77:2379,http://10.2.20.88:2379,http://10.2.20.99:2379"   endpoint status --write-out=table
+-----------------------------+------------------+---------+---------+-----------+------------+-----------+------------+--------------------+--------+
|          ENDPOINT           |        ID        | VERSION | DB SIZE | IS LEADER | IS LEARNER | RAFT TERM | RAFT INDEX | RAFT APPLIED INDEX | ERRORS |
+-----------------------------+------------------+---------+---------+-----------+------------+-----------+------------+--------------------+--------+
|  http://10.2.20.77:2379 | 52fba0ba228f3da3 |   3.4.9 |  2.1 GB |     false |      false |        50 |          9 |                  9 |        |
|  http://10.2.20.88:2379 | 4907167561836ce3 |   3.4.9 |  2.1 GB |      true |      false |        50 |          9 |                  9 |        |
|  http://10.2.20.99:2379 | b80cd01b4c2b7a1c |   3.4.9 |  2.1 GB |     false |      false |        50 |          9 |                  9 |        |
+-----------------------------+------------------+---------+---------+-----------+------------+-----------+------------+--------------------+--------+
相关推荐
yuzhiboyouye2 分钟前
内连接,左连接,右连接怎么区别开来?
数据库
铭毅天下17 分钟前
Easysearch 版本进化全图——从 ES 国产替代到 AI Native 搜索数据库
大数据·数据库·人工智能·elasticsearch·搜索引擎
szxinmai主板定制专家23 分钟前
电力设备RK3568/RK3576+FPGA,多系统混合部署Linux+RTOS RT-THREAD,强实时性
linux·运维·服务器·人工智能·嵌入式硬件·fpga开发
muddjsv24 分钟前
SQL 最常用技能详解与实战示例
数据库·sql·mysql
枕星而眠33 分钟前
Linux 四大进程/线程同步锁详解:互斥锁、读写锁、条件变量、文件锁
linux·c语言·后端·ubuntu·学习方法
L、2181 小时前
CANN调优工具链全景:从profiler到tensorboard的完整观测体系
linux·运维·服务器·深度学习
j_xxx404_2 小时前
Linux进程信号捕捉与操作系统运行本质深度解析
linux·运维·服务器·开发语言·c++·人工智能·ai
eggrall2 小时前
Linux信号——保存信号
linux·运维·服务器
2501_920047032 小时前
firewalld的使用
linux·运维
muddjsv2 小时前
大中小型企业数据配置年度成本估算分析
数据库·企业运营