KubeVirt备份与还原方案【翻译】
KubeVirt备份与还原方案【翻译】
ref:https://github.com/kubevirt/kubevirt/blob/main/docs/backup-restore-integration.md
备份
- 为所有必需的k8s资源构建依赖关系图
- 冻结应用程序
- pvc数据快照
- 解冻应用程序
- 将所有必需的k8s资源定义拷贝到一个共享的存储位置
- (可选)将PVC数据快照导出到一个共享存储位置
步骤3、5、6不在本文档讨论范围之内
恢复
- 使用快照数据填充PVC
- 清理并应用所有相关的k8s资源定义
步骤1超出本文档讨论范围
现有的Kubevirt备份解决方案
velero 插件
Velero是用来备份/迁移k8s集群的。kubevirt团队积极维护了一个用于velero的插件。这个插件实现了不少本文档所描述的逻辑。
VirtualMachineSnapshot + VirtualMachineExport API
vm快照和vm导出api
vm snapshot api为kubevirt用户提供了一种快捷的方式来在集群中备份vm。它本身不适合异地备份或灾难恢复。但是跟vm export api一起使用,vm的存储卷就可以被用来拷贝数据到远程位置。
建立kubevirt对象图
!backup-graph.png
(主要就是vm-vmi-pod,以及datavolume-pvc)
对象图中的节点格式:APIGroup-Kind-namespace-name
VM 对象图
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:name: vm1namespace: ns1
...
- (“kubevirt.io”, “VirtualMachine”, “ns1”, “vm1”)
(apigroup 是 kubevirt.io,kind是VM,在ns1命名空间下,名字叫做vm1)
spec
(spec是kubevirt的crd中自定义内容较多的一个部分)
spec.instancetype
...
spec:instancetype:kind: VirtualMachineInstancetypename: small
...
- (“instancetype.kubevirt.io”, “VirtualMachineInstancetype”, “ns1”, “small”)
spe.preference
...
spec:preference:kind: VirtualMachinePreferencename: windows
...
- (“instancetype.kubevirt.io”, “VirtualMachinePreference”, “ns1”, “windows”)
spec.template
见vmi的对象图
VMI 对象图
apiVersion: kubevirt.io/v1
kind: VirtualMachineInstance
metadata:name: vmi1namespace: ns1
...
- (“kubevirt.io”, “VirtualMachineInstance”, “ns1”, “vmi1”)
- (“”, “Pod”, “ns1”, “virt-launcher-vmi1-XXXXX”) *
*每个VMI有一个关联的唯一命名的pod,备份过程可以通过使用 kubevirt.io/created-by=<vmi uid>来寻找这个pod的名称
spec.volumes[*].persistentVolumeClaim
...
spec:volumes:- name: v1persistentVolumeClaim:claimName: pvc1
...
- (“”, “PersistentVolumeClaim”, “ns1”, “pvc1”)
- (“cdi.kubevirt.io”, “DataVolume”, “ns1”, “pvc1”)
spec.volumes[*].dataVolume
...
spec:volumes:- name: v1dataVolume:name: dv1
...
- (“”, “PersistentVolumeClaim”, “ns1”, “dv1”)
- (“cdi.kubevirt.io”, “DataVolume”, “ns1”, “dv1”)
spec.volumes[*].configMap
...
spec:volumes:- name: v1configMap:name: cm1
...
- (“”, “ConfigMap”, “ns1”, “cm1”)****
(剩下的就不一一复制粘贴了)
- (“”, “Secret”, “ns1”, “s1”)
- (“”, “ServiceAccount”, “ns1”, “sa1”)
- (“”, “PersistentVolumeClaim”, “ns1”, “pvc1”)
- • (“”, “Secret”, “ns1”, “my-pub-key”)
- • (“”, “Secret”, “ns1”, “my-user-password”)
VMI ReplicaSet
- (“kubevirt.io”, “VirtualMachineInstanceReplicaSet”, “ns1”, “vmirs1”)
- (“kubevirt.io”, “VirtualMachineInstance”, “ns1”, “vmirs1XXXX1”) *
- (“kubevirt.io”, “VirtualMachineInstance”, “ns1”, “vmirs1XXXX2”) *
*一般都有多个VMI关联在一个VMIReplicaSet中,备份过程可以搜寻kubevirt.io/vmReplicaSet= 作为标签选择器。
备份动作
用户文件系统冻结/解冻hook
还原动作
VM还原
如果还原到不同的集群,并且明确设置了mac地址或bios序列号,需要确保不会发生冲突,在这里设置:
/spec/template/spec/domain/devices/interfaces/<index>/macAddress
/spec/template/spec/domain/firmware/serial
VMI还原
如果一个VMI归属于一个VM,则这个VMI不应该被还原。kubevirt controller会根据VM定义重建VMI。否则,VMI定义有可能以VM相同预配置的Mac/bios进行恢复(可能导致重复)。
virt-launcher pod 还原
属于一个VMI,带有”virt-launcher-”前缀的pod不应该被还原。
DataVolume还原
在succeeded阶段的datavolumes需要在还原期间设置以下annotation。否则关联的pvc可能有损坏。除了Succeeded之外任何阶段的datavolumes都不需要注释。
cdi.kubevirt.io/storage.prePopulated: <datavolume name>
PVC还原
归属于DataVolumes的PVC必须在备份/还原时加annotation
cdi.kubevirt.io/storage.populatedFor: <datavolume name>
相关文章:
KubeVirt备份与还原方案【翻译】
KubeVirt备份与还原方案【翻译】 ref:https://github.com/kubevirt/kubevirt/blob/main/docs/backup-restore-integration.md 备份 为所有必需的k8s资源构建依赖关系图冻结应用程序pvc数据快照解冻应用程序将所有必需的k8s资源定义拷贝到一个共享的存储位置(可选…...
使用PyQt5设计一款简单的计算器
目录 一、环境配置: 二、代码实现 三、主程序 四、总结 本文使用PyQt5设计一款简单的计算器,可以通过界面交互实现加减乘除的功能,希望能够给初学者一些帮助。主要涉及的知识点有类的定义与初始化、类的成员函数、pyqt5的信号与槽函数等。…...
Htop使用说明
目录 引言 什么是htop htop安装 htop界面介绍 htop功能介绍 引言 我们使用服务器的时候常常需要关注下自己的程序资源占用情况,htop就是一种互动式的进程查查看器,整齐用下来感觉比top的逼格高,造作可视化都更方便些,我觉得还…...
PostgreSQL Linux安装
安装依赖: sudo yum -y install readline-devel zlib-devel 安装Postgres: ssh hadoophadoop001 #下载Postgres wget https://ftp.postgresql.org/pub/source/v14.2/postgresql-14.2.tar.gz tar -zxvf postgresql-14.2.tar.gz -C /data #编译前准备 /dat…...
亚商投资顾问 早餐FM/0509车辆电动化
01/亚商投资顾问 早间导读 1.上交所拟于5月11日举办“发现央企投资价值,促进央企估值回归”交流会 2.监管部门十方面举措加强房地产经纪行业管理 3.广东:推动城市公共服务及货运配送车辆电动化替代 4.昆山两楼盘因大幅降价被暂停网签:降幅…...
AI绘画天花板——Midjourney注册使用保姆级教程(5月5日验证有效)
大家好,我是可夫小子,关注AIGC、读书和自媒体。解锁更多ChatGPT、AI绘画玩法。加我,备注:aigc,拉你进群。 现在市面上AI绘图大概有三大阵营:Midjourney、Stable Diffusion,还有一个就是OpenAI实…...
学习笔记(2)项目结构描述 - manifest.json和pages.json
目录 1,manifest.json2,pages.json2.1,pages2.2,globalStyle2.3,tabBar 1,manifest.json 官方详情 uni-app 的 appid 由 DCloud 云端分配,主要用于 DCloud 相关的云服务,请勿自行修…...
vector、deque、list相关知识点
vector erase返回迭代器指向删除元素后的元素insert返回迭代器指插入的元素reserve只给容器底层开指定大小内存空间,并不添加新元素 deque 底层数据结构 动态开辟的二维数组,一维数组从2开始,以2倍方式扩容,每次扩容和&#x…...
多维时序 | MATLAB实现基于VMD-SSA-LSSVM、SSA-LSSVM、VMD-LSSVM、LSSVM的多变量时间序列预测对比
多维时序 | MATLAB实现基于VMD-SSA-LSSVM、SSA-LSSVM、VMD-LSSVM、LSSVM的多变量时间序列预测对比 目录 多维时序 | MATLAB实现基于VMD-SSA-LSSVM、SSA-LSSVM、VMD-LSSVM、LSSVM的多变量时间序列预测对比预测效果基本介绍程序设计学习总结参考资料 预测效果 基本介绍 多维时序 …...
设计模式——适配器模式(类适配器、对象适配器)
是什么? 我们平时的有线耳机接口分为USB的和Type-C的接口,但是手机的耳机插口却只有一个,像华为的耳机插口现在基本都是Type-c的,那如果我们现在只有USB接口的耳机怎么办呢,这个时候就需要使用到一个转换器,…...
iOS开发多target
场景 背景:设想一下有一个场景,一个业务分为多种身份,他们大部分功能是相同的,但是也有自己的差异性。这种情况,想要构建出不同身份的APP。你会怎么做??? 当然,你可以拷贝一份代码出来,给项目重新命名。这样做的好处是,他们互相不会冲突,不用去关心是否有逻辑的冲…...
100种思维模型之每日评估思维模型-58
曾子曰:吾日三省吾省,为人谋而不忠乎?与朋友交不信乎?传不习乎? 曾国藩,坚持每日写复盘日记,最后他用自己的实践经历向我们证明:一个智商很平庸、出身很普通且有着各种毛病的人&…...
libreoffice api
libreOffice API是用于访问libreOffice的编程接口。可以使用libreOffice API创建、打开、修改和打印libreOffice文档。 LibreOffice API支持Basic、Java、C/C、Javascript、Python语言。 这是通过一种称为通用网络对象 (Universal Network Objects, UNO) 的技术实现的ÿ…...
全网最火,Web自动化测试驱动模型详全,一语点通超实用...
目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 自动化测试模型&a…...
如何写软件测试简历项目经验,靠这个面试都要赶场
一、前言:浅谈面试 面试是我们进入一个公司的门槛,通过了面试才能进入公司,你的面试结果和你的薪资是息息相关的。那如何才能顺利的通过面试,得到公司的认可呢?面试软件测试要注意哪些问题呢?下面和笔者一起来看看吧。这里分享一…...
【Linux】Linux下安装Mysql(图文解说详细版)
文章目录 前言第一步,进到opt文件夹下面,为什么?因为opt文件夹相当于Windows下的D://software第二步,用yum安装第三步,设置mysql的相关配置第四步,设置远程连接。第五步,更改mysql的语言第六步&…...
Cookie和Session的API、登录页面
目录 一、Cookie 和 Session 1、HttpServletRequest 类中的相关方法 2、HttpServletResponse 类中的相关方法 3、HttpSession 类中的相关方法 4、Cookie 类中的相关方法 二、网页登录 1、约定前后端交互接口 2、编写一个简单的登录页面 3、编写一个Servlet 来处理这个…...
C++数据结构:手撕红黑树
目录 一. 红黑树的概念及结构 二. 红黑树节点的定义 三. 红黑树节点的插入 3.1 初步查找插入节点的位置并插入节点 3.2 红黑树结构的调整 3.3 红黑树节点插入完整版代码 四. 红黑树的结构检查 4.1 检查是否为搜索树 4.2 检查节点颜色是否满足要求 附录:红黑…...
Spring IoC 深度学习
Io回顾 IoC 是 Inversion of Control 的简写,译为“控制反转”,它不是一门技术,而是一种设计思想,是一个重要的面向对象编程法则,能够指导我们如何设计出松耦合、更优良的程序。 Spring 通过 IoC 容器来管理所有 Jav…...
C语言从入门到精通第17天(指针和数组联用)
指针和数组联用 不同类型指针变量之间的区别数组的指针指针数组 不同类型指针变量之间的区别 在了解数组和指针联用之前,我们先对指针变量进行补充。我们对比一下int *p1和char *p2的区别? 相同点: 都是指针变量都是用来保存一个内存地址编…...
别再只会用torchvision.models了!手把手教你从零理解ResNet18的PyTorch实现(附完整代码)
从零构建ResNet18:深入理解PyTorch实现与模型定制技巧 在深度学习领域,ResNet已经成为计算机视觉任务中不可或缺的基础架构。许多开发者习惯于直接调用torchvision.models.resnet18()这一行魔法代码,却对背后的实现细节知之甚少。本文将带你从…...
告别集群负载:用Docker Compose在外部机器部署Prometheus+Grafana监控K8S(附完整配置文件)
轻量化监控方案:Docker Compose 部署 PrometheusGrafana 监控 Kubernetes 集群 对于资源有限的中小团队或个人开发者来说,将监控系统与业务集群分离是一个明智的选择。传统的 Kubernetes 监控方案通常将 Prometheus 和 Grafana 部署在集群内部࿰…...
华测RTK静态数据解算保姆级教程:从CHC Geomatics Office 2安装到平差报告导出
华测RTK静态数据解算全流程实战指南:从软件配置到精度优化 第一次接触华测RTK静态解算时,面对满屏的专业术语和复杂参数,不少同行都有过这样的困惑:为什么同样的数据,别人处理出来的结果总能一次性通过验收࿰…...
LangChain4j-examples:基于Java的AI智能体工作流编排深度解析与实践指南
LangChain4j-examples:基于Java的AI智能体工作流编排深度解析与实践指南 【免费下载链接】langchain4j-examples 项目地址: https://gitcode.com/GitHub_Trending/la/langchain4j-examples LangChain4j-examples是一个面向Java开发者的AI智能体工作流编排框…...
终极指南:5分钟在Windows上安装安卓APK文件,无需模拟器
终极指南:5分钟在Windows上安装安卓APK文件,无需模拟器 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否厌倦了笨重的安卓模拟器ÿ…...
从ST转战小华HC32F448:一个电机控制老兵的实战避坑与快速上手指南
从ST转战小华HC32F448:一个电机控制老兵的实战避坑与快速上手指南 当国产MCU的性价比优势逐渐凸显,越来越多的工程师开始关注小华半导体这类新兴玩家。作为深耕电机控制领域多年的开发者,我最近在变频器项目中尝试了HC32F448这颗芯片…...
Altium Designer 21 实战:用Pad/Via模板库,5分钟搞定BGA盲埋孔PCB设计
Altium Designer 21 高效设计:用Pad/Via模板库5分钟完成BGA盲埋孔布局 面对0.65mm间距BGA封装的设计需求,传统手动设置焊盘和过孔的方式不仅耗时,还容易因参数输入错误导致生产问题。Altium Designer 21的Pad/Via模板功能,让工程师…...
保姆级教程:手把手解决CANoe 17.0在Win11系统上的安装失败问题(附临时文件夹清理方法)
CANoe 17.0在Windows 11系统安装全攻略:从权限配置到环境优化 当汽车电子工程师第一次在Windows 11系统上安装CANoe 17.0时,可能会遇到各种意想不到的障碍。不同于常见的软件安装过程,这款专业工具对系统环境有着更为严格的要求。本文将深入…...
别再乱接线了!用PulseView+逻辑分析仪抓STM32 SPI波形,保姆级避坑指南
逻辑分析仪实战:精准捕获STM32 SPI波形的五大黄金法则 当你在调试STM32的SPI外设时,是否遇到过这样的困境:代码配置完全按照手册操作,但逻辑分析仪显示的波形却充满毛刺、数据残缺不全?这往往不是代码逻辑的问题&#…...
逆向实战:用WT-JS_DEBUG_V1.8.3快速定位并导出AES加密参数到Python
逆向工程实战:从浏览器到Python的AES加密参数高效迁移指南 在数据采集和接口分析领域,遇到前端加密是再常见不过的挑战。特别是当网站采用AES加密时,如何快速提取关键参数并复用到Python脚本中,成为许多开发者头疼的问题。本文将…...
