Rancher 单节点 docker 部署备份与恢复

Rancher 单节点 docker 部署备份与恢复

1. 备份集群
  1. 获取 rancher server 容器名,本例为 angry_aryabhata

    shell 复制代码
    docker ps | grep rancher/rancher
    
    6a27b8634c80   rancher/rancher:v2.5.14           xxx		   angry_aryabhata
  2. 停止容器

    shell 复制代码
    docker stop angry_aryabhata
  3. 创建备份容器,其中 rancher-data-06071539 建议按照日期时间命名

    shell 复制代码
    docker create --volumes-from angry_aryabhata --name rancher-data-06071539 rancher/rancher:v2.5.14

    打包容器内数据目录,此处 --volumes-from 需填写上一步的容器名称

    shell 复制代码
    docker run --volumes-from rancher-data-06071539 -v $PWD:/backup:z \
    busybox:latest tar pzcvf \
    /backup/rancher-data-backup-v2.5.14-06071539.tar.gz /var/lib/rancher
  4. 查看当前目录下是否有备份文件 rancher-data-backup-v2.5.14-06071539.tar.gz

  5. 删除第 3 步创建的备份数据容器

    shell 复制代码
    docker rm -f rancher-data-06071539
  6. 重新启动 rancher server 容器即可

    shell 复制代码
    docker start angry_aryabhata

2. 恢复集群
  1. 为了对比验证,首先删除 rancher server 数据目录,此时 rancher 已完全崩溃

    shell 复制代码
    rm -rf /home/rancher/
  2. 停止 rancher server 容器

    shell 复制代码
    docker stop angry_aryabhata
  3. 从备份文件恢复

    shell 复制代码
    docker run --volumes-from angry_aryabhata -v $PWD:/backup \
    busybox:latest sh -c "rm /var/lib/rancher/* -rf && \
    tar pzxvf /backup/rancher-data-backup-v2.5.14-06071539.tar.gz"
  4. 重新启动 rancher server 容器

    shell 复制代码
    docker start angry_aryabhata

3. 备份脚本

如果不想手动执行命令,可以使用以下脚本备份,本人 shell 水平有限,如有错误或优化空间还请指正~

shell 复制代码
#!/bin/bash

# 获取 Rancher 容器名称
container_name=$(docker ps | grep rancher/rancher | awk '{print $NF}')

echo "容器名:$container_name"

echo "第一步:停止 Rancher 容器"

docker stop $container_name


echo "第二步:创建备份容器"
# 获取当前日期
current_date=$(date "+%Y%m%d")

docker create --volumes-from $container_name \
	--name rancher-data-$current_date \
	rancher/rancher:v2.5.14


echo "第三步:打包数据文件"
# 以日期戳命名备份文件
file_name="/backup/rancher-data-backup-v2.5.14-$current_date.tar.gz"

docker run --volumes-from rancher-data-$current_date -v $PWD:/backup:z \
	busybox:latest tar pzcvf $file_name /var/lib/rancher

# 判断备份文件是否生成到当前目录下
file_name_local=$(basename "$file_name")
if [ -f "$file_name_local" ]; then
	echo "备份文件已生成:$file_name_local"
else
	echo "备份文件未生成,请检查!"
	exit 1
fi


echo "第四步:删除备份容器"

docker rm -f rancher-data-$current_date


echo "第五步:重新启动 Rancher 容器"

docker start $container_name
相关推荐
“码”力全开7 分钟前
深度解析:基于 Docker 与边缘计算的国产化 AI 视频管理平台,如何通过源码交付实现多协议(GB28181/RTSP)与异构算力解耦?
人工智能·docker·边缘计算
“码”力全开11 分钟前
基于 Docker 容器化与异构计算的工业级视频中台架构:GB28181/RTSP 双协议栈统一接入与源码交付深度解析
docker·架构·音视频
ai产品老杨30 分钟前
Docker分布式部署与GB28181/RTSP全协议汇聚:基于源码交付的异构边缘计算AI视频管理平台架构解析
docker·容器·架构
xier_ran42 分钟前
【infra之路】模块三:Kubernetes (上) — 概念、集群搭建、Pod 与 Deployment
云原生·容器·kubernetes
IT策士43 分钟前
第 23篇 k8s之Pod:多容器 Pod 与设计模式(Sidecar 等)
设计模式·容器·kubernetes
ai产品老杨1 小时前
解耦视频流利器:如何利用 GB28181 与 RTSP 协议统一收敛多厂商设备?一套支持 Docker 部署与源码交付的边缘计算 AI 视频中台深度解析
人工智能·docker·边缘计算
专业白嫖怪9 小时前
什么是docker
运维·docker·容器
qq_4523962314 小时前
第十篇:《Dockerfile 最佳实践与镜像瘦身》
docker
Plastic garden14 小时前
Docker(1)
运维·docker·容器
gs8014015 小时前
网络隐形杀手:从 Could not connect to SMTP host 报错深度剖析 Docker MTU 黑洞理论与实战
网络·docker·容器