k8s备份恢复工具--velero

k8s的备份和恢复工具

主要包括服务端和客户端两部分,服务端运行在k8s集群中,客户端运行在本地的命令行,本地需要配置好k8s的kubeconfig和kubectl客户端工具

需要对象存储当做中间备份或存储的工具(S3,minio,OSS等)

工作原理即是将k8s资源备份到对象存储当中,并可以从对象存储中拉取备份数据来恢复集群资源对象

velero地址https://github.com/vmware-tanzu/velero

下面操作的机器是配置好k8s的kubectl和kubeconfig的

下载velero客户端

bash 复制代码
wget https://github.com/vmware-tanzu/velero/releases/download/v1.13.1/velero-v1.13.1-linux-amd64.tar.gz
tar -zxvf velero-v1.13.1-linux-amd64.tar.gz
cp velero-v1.13.1-linux-amd64/velero /usr/local/bin

搭建minio代替S3文件存储

https://min.io/docs/minio/linux/index.html

bash 复制代码
wget https://dl.min.io/server/minio/release/linux-amd64/archive/minio-20240330094156.0.0-1.x86_64.rpm -O minio.rpm
rpm -ivh minio.rpm
nohup minio server ~/minio --console-address :9001 &

访问http://IP:9000,minioadmin/minioadmin

部署velero服务端

首先需要将minio的验证信息写入文件中

bash 复制代码
cat access-minio
  [default]
  aws_access_key_id = minioadmin
  aws_secret_access_key = minioadmin

然后写部署velero服务端的脚本

bash 复制代码
vim velero.sh
velero install --provider aws --plugins velero/velero-plugin-for-aws:v1.9.0 --bucket velero --secret-file ./access-minio --kubeconfig=/root/.kube/test-config --use-volume-snapshots=false --backup-location-config region=minio,s3ForcePathStyle="true",s3Url=http://10.8.0.11:9000

运行脚本

bash 复制代码
bash velero.sh

运行之后会在k8s集群中创建出velero的namespace和velero的服务端

执行命令进行备份

bash 复制代码
velero backup create velero-backup --namespace=velero
#查看备份
velero get backup

备份完成之后即可在minio中看到备份文件的生成

恢复

bash 复制代码
velero restore create --from-backup=velero --kubeconfig=
相关推荐
运维栈记5 小时前
如何排错运行在Kubernetes集群中的服务?
云原生·容器·kubernetes
阿里云云原生7 小时前
直播回顾丨详解阿里云函数计算 AgentRun,手把手带你走进 Agentic AI 生产时代
云原生
木卫二号Coding8 小时前
affine+docker+postgresql+备份数据库
数据库·docker·容器
檀越剑指大厂8 小时前
查看 Docker 镜像详情的几种常用方法
docker·容器·eureka
java_logo9 小时前
Webtop Docker 容器化部署指南:基于浏览器的Linux桌面环境
linux·docker·容器·webtop·webtop部署教程·docker部署webtop·linux桌面
源去_云走10 小时前
自建 Iconfy API 服务:解决国内访问不稳定问题
前端·容器·npm·node.js
技术小李...10 小时前
docker下mysql更改密码后WordPress提示无法连接数据库问题
运维·docker·容器
叫致寒吧13 小时前
zookeeper与kafka
分布式·zookeeper·云原生
爱学大树锯13 小时前
在Docker环境中安装RabbitMQ延迟消息插件实战记录
docker·容器·rabbitmq
木风小助理13 小时前
Kubernetes持久化存储架构深度解析:从易失的Pod到永恒的数据
kubernetes