当前位置: 首页 > news >正文

ETCD 集群备份与恢复

echo "=== 查看数据 ==="

docker exec -it etcd_etcd3_1 etcdctl --endpoints=http://192.168.100.91:32379 get "" --from-key

docker exec -it etcd_etcd3_1 etcdctl --endpoints=http://192.168.100.91:32379 get '/test' --prefix

docker exec -it etcd_etcd3_1 etcdctl --endpoints=http://192.168.100.91:32379 get '/test' --prefix --keys-only

etcdctl get "" --from-key --keys-only // 查看备份文件中的数据

etcdctl get '/apisix' --prefix --keys-only // 查看备份文件中的数据

echo ""

echo "=== 备份与恢复测试 ==="

docker exec etcd_etcd3_1 etcdctl --write-out=table snapshot status /bitnami/etcd/data/etcd_backup.db

echo "=== 备份目标数据 ==="

docker exec etcd_etcd3_1 etcdctl --endpoints=http://localhost:2379 snapshot save /bitnami/etcd/etcd_backup.db

echo "=== 导出备份数据 ==="

docker cp etcd_etcd3_1:/bitnami/etcd/data/etcd_backup.db /tmp/etcd_backup/

echo "=== 查看备份数据 ==="

docker exec etcd_etcd3_1 etcdctl --write-out=table snapshot status /bitnami/etcd/etcd_backup.db




echo "=== 关闭集群(如果已经启动) ==="

docker-compose -f 1/docker-compose.yml down

docker-compose -f 2/docker-compose.yml down

docker-compose -f 3/docker-compose.yml down

echo "=== 移出旧数据 ==="

mv 2/data2 bak2

mv 1/data1 bak1

mv 3/data3 bak3

echo "=== 使用临时容器处理数据,三个节点依次生成数据 ==="

docker run --rm \

-v /tmp/etcd_backup:/backup \

-v /etcd_cluster/2/data2:/var/etcd \

quay.io/coreos/etcd:v3.5.12 \

etcdutl snapshot restore /backup/etcd_backup.db \

--name etcd-2 \

--data-dir /var/etcd \

--initial-advertise-peer-urls http://192.168.100.91:2390 \

--initial-cluster "etcd-1=http://192.168.100.91:2380,etcd-2=http://192.168.100.91:2390,etcd-3=http://192.168.100.91:2370" \

--initial-cluster-token etcd-cluster

docker run --rm \

-v /tmp/etcd_backup:/backup \

-v /etcd_cluster/1/data1:/var/etcd \

quay.io/coreos/etcd:v3.5.12 \

etcdutl snapshot restore /backup/etcd_backup.db \

--name etcd-1 \

--data-dir /var/etcd \

--initial-advertise-peer-urls http://192.168.100.91:2380 \

--initial-cluster "etcd-1=http://192.168.100.91:2380,etcd-2=http://192.168.100.91:2390,etcd-3=http://192.168.100.91:2370" \

--initial-cluster-token etcd-cluster

docker run --rm \

-v /tmp/etcd_backup:/backup \

-v /etcd_cluster/3/data3:/var/etcd \

quay.io/coreos/etcd:v3.5.12 \

etcdutl snapshot restore /backup/etcd_backup.db \

--name etcd-3 \

--data-dir /var/etcd \

--initial-advertise-peer-urls http://192.168.100.91:2370 \

--initial-cluster "etcd-1=http://192.168.100.91:2380,etcd-2=http://192.168.100.91:2390,etcd-3=http://192.168.100.91:2370" \

--initial-cluster-token etcd-cluster

echo "=== 启动集群 ==="

docker-compose -f 1/docker-compose.yml up -d

docker-compose -f 2/docker-compose.yml up -d

docker-compose -f 3/docker-compose.yml up -d

echo "=== 检查集群状态 ==="

docker exec -it etcd-s1 etcdctl --endpoints=http://192.168.100.91:2379,http://192.168.100.91:2369,http://192.168.100.91:2389 endpoint status -w table

echo "=== 测试数据写入同步 ==="

echo "在节点1写入数据..."

docker exec etcd-s1 etcdctl --endpoints=http://192.168.100.91:2379 put cluster_test "etcd-s1"

echo "从节点2读取数据..."

docker exec etcd-s2 etcdctl --endpoints=http://192.168.100.91:2369 get cluster_test

echo "从节点3读取数据..."

docker exec etcd-s3 etcdctl --endpoints=http://192.168.100.91:2389 get cluster_test

echo "查看数据"

docker exec -it etcd-s1 etcdctl --endpoints=http://192.168.100.91:32379 get '/test' --prefix --keys-only

http://www.dtcms.com/a/540421.html

相关文章:

  • ETCD 常用命令
  • 低空经济网络安全风险
  • 【音视频】B站的流媒体协议
  • GVHMR——基于重力-视角坐标的人体运动恢复:从RGB视频中提取人的SMPL轨迹(包含人体姿态估计WHAM、手势估计HaMeR的详解)
  • 【ROS2】驱动开发-通过控制器访问硬件(Hardware Access through Controllers)
  • 智能网联汽车网络发展总体目标:构建“泛在接入、能力协同、安全可信“的立体化体系
  • 网站可以备案先提交类别后来改么网站如何被百度快速收录
  • 【软考架构】案例分析:状态图和活动图的定义以及区别
  • 制作营销网站公司有没有做网站的
  • HarmonyOS 性能优化与安全开发:打造高效且安全的智能应用
  • 从TSX到JS:深入解析npm run build背后的完整构建流程
  • NAS助手 — 纯血鸿蒙时代的 NAS 文件分享新方案
  • HarmonyOS应用性能调优与内存管理实战
  • pulsar与kafka的架构原理异同点
  • 做火锅加盟哪个网站好五屏网站建设平台
  • 帮别人做网站违法大秦建设集团有限责任公司官方网站
  • 地轨的定义与用途
  • 使用Docker轻松搭建WordPress博客:完整指南
  • 电路学习——4个IO口控制12个LED(2025.10.28)
  • 【学习笔记】Ubuntu Linux使用过程问题记录
  • 机器学习/深度学习 信号处理 评估指标速查表
  • 惠州做网站的公司有哪些做电子元器件销售什么网站好
  • “LangChain 版化工厂危险行为告警系统”的完整项目
  • 【React的Fiber及中断-重启逻辑的设计】
  • 石狮建设网站网站建设费要摊销
  • 人工智能——K-Means聚类进行青少年市场细分实践
  • 卷积运算全解析:从原理到MATLAB实现
  • BIM+GIS尝试
  • vscode关闭自动激活conda环境
  • jdk动态代理实现原理(二)