##安装velero
wget https://github.com/vmware-tanzu/velero/releases/download/v1.11.0/velero-v1.9.3-linux-amd64.tar.gz tar zxvf velero-v1.9.3-linux-amd64.tar.gz cp velero-v1.9.3-linux-amd64/velero /usr/bin/
创建minio凭证,minio部署参照另一篇文章minio通过docker-compose部署
创建minio凭证文件
cat >credentials-velero <<EOF [default] aws_access_key_id = T6uyCVYwgIJe9ZWC7fDQ ws_secret_access_key = ********************** EOF
安装velero
因为有些环境拉取不到国外的镜像,所以我拉到本地打了tag上传到了阿里云,没有做任何修改,可放心使用
官方的参数像是--image velero/velero:v1.9.3 --plugins velero/velero-plugin-for-aws:v1.2.1
velero install \ --provider aws \ --image registry.cn-hangzhou.aliyuncs.com/zhengyu1992/velero:v1.9.3 \ --plugins registry.cn-hangzhou.aliyuncs.com/zhengyu1992/velero-plugin-for-aws:v1.2.1 \ --namespace velero \ --bucket velero \ --use-volume-snapshots=false \ --secret-file ./credentials-velero \ --default-volumes-to-restic \ --use-restic \ --backup-location-config region=minio,s3ForcePathStyle="true",s3Url=http://10.10.21.48:9000 \ --wait
卸载velero
kubectl delete namespace/velero clusterrolebinding/velero kubectl delete crds -l component=velero
迁移storageclass,我们的目的是将nfs-storage中的数据迁移到rook-ceph-block
创建一个声明yaml文件
vi change-storage-class-config.yaml apiVersion: v1 kind: ConfigMap metadata: name: change-storage-class-config namespace: velero labels: velero.io/plugin-config: "" velero.io/change-storage-class: RestoreItemAction data: nfs-storage: rook-ceph-block kubectl create -f change-storage-class-config.yaml
开始备份
velero backup create zadig-20230717 --include-namespaces zadig
查看备份进度
velero backup describe zadig-20230717
查看备份日志
velero backup logs zadig-20230717
这时候到minio控制台可以看到有数据已经写入了
#仅备份pv和pvc的参数(适用于仅更换存储类不迁移集群的情况)
velero backup create test--include-resources pvc,pv --include-namespaces zadig