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

K8S-etcd备份还原操作手册

1、备份操作

​​​​​​​1.1、环境说明

etcd备份和恢复脚本清单:

etcdbak.sh  //用于对etcd各节点进行备份,需要将该脚本拷贝至各节点统一目录。

etcdret.sh  //用于进行还原操作。

​​​​​​​1.2、备份修改脚本

 打开修改脚本修改如下配置信息

#具体节点地址 

#群各节点地址

#EtcdEndpoints="http://10.143.55.118:1159,http://10.143.55.119:1159,http://10.143.55.121:1159"

EtcdEndpoints=http://10.143.55.119:1159

#etcd客户端

EtcdCmd="/usr/bin/etcdctl"  

#备份主机地址

BackupHost="10.143.55.118"  

#备份数据目录

BackupDir="/data/backup/etcd/"   

#备份文件名

BackupFile="snapshot"$(date +%Y%m%d)_$(date +%H%M%S)".db"

#ca证书

CertFile="/etc/kubernetes/ssl/etcd/ca.crt"  

#/etcd证书

ServerFile="/etc/kubernetes/ssl/etcd/server.crt"

#etcd证书key

KeyFile="/etc/kubernetes/ssl/etcd/server.key"

#集群名称

EtcdToken="cc34c326-4694-48c6-afdf-c317f40c1847"

# 是否启动etcd证书

CertBoolen="false"

#etcd名称

EtcdName="etcd55_118"

# etcd集群是否健康

Ishealth="false"

​​​​​​​1.3、手动执行脚本测试

 chmod +x  etcdbak.sh

 sh ectdbak.sh

​​​​​​​1.4、检查备份文件是否存在

 切换到备份数据目录下,查找以当前日期结尾的备份文件如

​​​​​​​1.5、注意事项

(1)如果在脚本执行过程中,出现etcd集群节点错误,则需要首先修复etcd正常运行,否则长时间备份连线etcd 会增加etcd集群崩溃风险,脚本在执行前进行检查,若集群状态不健康,不进行备份。

(2)备份为周期为每天,所以注意检查磁盘容量并及时删除多余备份数据。​​​​​​​

1.6、设置备份周期

向 vi /etc/crontab 追加记录 【注意按实际脚本存放位置和自定义周期修改追加信息,默认为每天凌晨三点备份】

0  3  *  *  * root  /data/backup/ etcdbak.sh

 保存生效

加载任务,使之生效:crontab /etc/crontab

查看任务:crontab -l

​​​​​​​1.7、日志调取

 各节点在etcd备份文件同级目录下查看etcdbak.log

2、还原操作

2.1、停止etcd

ansible etcd -m shell -a "systemctl stop etcd" -i hosts

2.2 、清空

ansible etcd  -m shell  -a "rm -rf /apps/etcd_data/*" -i hosts

​​​​​​​2.3、分发还原数据到各节点

发同一份数据至各etcd节点同一目录下

ansible etcd copy -a -m "src= /data/backup/etcd/snapshot.db20211112_200249.db dest= /data/backup/etcd/ owner=root group=root mode=0644 " -i hosts

​​​​​​​2.4、修改各节点脚本配置

​​​​​​​2.5、导入操作

chomd  +x  etcdrest.sh

sh    etcdrest.sh

2.6、启动etcd

ansible etcd -m shell -a "systemctl start etcd" -i hosts

2.7、恢复后检查

Kubectl get pod -A

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

相关文章:

  • 网络华为HCIA+HCIP NFV
  • 996引擎-接口测试:消息Tips
  • 【leetcode hot 100 17】电话号码的字母组合
  • GCC 预定义宏:解锁编译器的隐藏信息
  • 使用Docker运行 Ollama本地部署 DeepSeek 模型并用Dify实现可视化操作
  • 使用DeepSeek查找资料:C++ sprintf % 种类
  • 视频剪辑行业的现状与进阶之路:一个双视角分析
  • 《Android 13深度定制:手势拦截技术实现SystemUI状态栏智能折叠方案》
  • Java-校验值区间值的连续性
  • 每天学一个 Linux 命令(6):shutdown
  • Java八股
  • 【设计模式】三十二、策略模式
  • buu-bjdctf_2020_babystack2-好久不见51
  • Nodejs 项目打包部署方式
  • 博客系统自动化测试报告
  • Java实现十大经典排序算法详解
  • firefly经典蓝牙和QProcess记录
  • MinIO
  • 使用 Apktool 反编译、修改和重新打包 APK
  • 1978-2022年全国及31省农业机械总动力数据(无缺失)
  • 开源ORB_SLAM2项目编译常见问题与应对办法
  • 分布式(一):CAPBASE理论
  • Excel(实战):INDEX函数和MATCH函数
  • QSettings修改配置后强制重启应用导致配置文件大小为0问题
  • 基于Azure Delta Lake与Databricks的医疗数据变更管理
  • 优选算法训练篇08--力扣15.三数之和(难度中等)
  • 第4章 IP网络扫描(网络安全评估)
  • 【科研杂记_10】国家行政区划可视化
  • [特殊字符][特殊字符][特殊字符][特殊字符][特殊字符][特殊字符]壁紙 流光染墨,碎影入梦
  • C++基础 [十二] - 继承与派生