xen save/restore 过程

以下分析基于 xen4.2.3, 虚拟机都是hvm模式

使用libxl库有两种方式启动一个虚拟机,一种是 xl create xx.conf ,
这种方式从一个配置文件开始启动一个虚拟机,速度相对较慢。另一种是xl restore checkpointfile ,
这种从一个checkpoint文件启动(恢复)虚拟机,速度非常快。 checkpointfile
可以认为是一个虚拟机快照,保存了虚拟机某一时刻的内存和设备状态,这里的‘某一时刻’其实就是执行保存快照  xl save domainname
checkpointfile 的时刻。

一. xl  save 流程

假设一开始是从xl create的方式启动的虚拟机 domtest, 执行到某一时刻相要通过xl save保存快照,xl save
执行的时候涉及多个进程,如下:

进程1: xl create domtest.conf

进程2: qemu-dm

进程3: xl save

进程4: libxl_save_helper (xen4.2 引入的)

一般xl create虚拟机后会发生多次fork和daemon调用,但完全启动之后主要的应用层进程就是 xl create 和 Qemu-dm
两个精灵进程。xl save执行时候还涉及两个文件,如下:

文件1: /var/lib/xen/userdata-d.domid.domuuid 文件

文件2:/var/lib/xen/qemu-resume.domid 文件

xl create过程中,虚拟机的配置会被保留一份在上述文件1里,而文件2是在xl
save执行过程中由qemu-dm进程产生的。

下面是 "xl save checkpointfile "  命令执行的基本过程:

1. xl save 进程将文件1拷贝到checkpointfile文件开头

2. xl save 进程调用fork, 子进程调用 execvp 载入可执行程序 libxl-save-helper 变成进程4,
这个helper进程通过 libxc 库将虚拟机的整个内存状态保存在一个虚拟地址开始的内存空间里,这个虚拟地址是启动 libxl-save-helper时由
xl save 进程传进去的

3. 在子进程执行libxl-save-helper时,父进程执行下述步骤

3.1 调用 xc_domain_shutdown 关闭虚拟机,并进入一个循环,循环内调用 xc_domain_getinfolist
查看虚拟机是否关闭,如果关闭退出循环进入3.2. 这一步执行完之后,xl create进程就死掉了

3.2 调用xenstore接口往  /local/domain/0/device-model/%d/command 键写入
‘save‘ , 这会导致进程进程3 qemu-dm 将设备状态保存到文件
/var/lib/xen/qemu-save.xx,保存好之后,qemu-dm会进入状态paused

3.3 进入一个循环,循环内检测/local/domain/0/device-model/1/state 的值是否为 paused
,如果不是等待超时

3.4 如果在3.3超时退出,则save失败。如果没有超时,则开始等待 libxl-save-helper 进程,如果后者执行完成,则执行3.5

3.5 将
/var/lib/xen/qemu-save.xx文件的内容拷贝到checkpointfile文件,至此,虚拟机的配置、内存、设备模型都已经保存到了checkpointfile文件

3.6 杀死 qemu-dm 进程并调用 libxc 接口删除虚拟机(内核部分的清理)

二 restore 流程

restore流程跟save流程基本相反, xl restore checkpointfile

1. 从checkpointfile里读取第一部分的配置部分,根据配置分配结构启动内核进程等等

2. 调用 libxl-save-helper , 恢复内存状态

3. 将checkpointfile 的最后设备模型那部分拷贝到 /var/lib/xen/qemu-save.xx文件, 并启动
Qemu-dm 进程, qemu-save.xx 文件作为 qemu-dm 的 loadvm 参数传进去

参考:

2010 的文章,比较老了,流程跟4.2 的也有些不一样:Fast, Lightweight Virtual Machine
Checkpointing

xen save/restore 过程,布布扣,bubuko.com

时间: 2024-10-17 21:25:05

xen save/restore 过程的相关文章

Android Canvas save() restore()

Android Canvas save() restore()

[ html canvas save restore ] canvas绘图 save restore 属性理论讲解

Canvas API详解(Part 1) 分类 Android 基础入门教程 本节引言: 前面我们花了13小节详细地讲解了Android中Paint类大部分常用的API,本节开始我们来讲解 Canvas(画板)的一些常用API,我们在 8.3.1 三个绘图工具类详解 中已经列出了我们可供调用的一些方法,我们分下类: drawXxx方法族:以一定的坐标值在当前画图区域画图,另外图层会叠加, 即后面绘画的图层会覆盖前面绘画的图层. clipXXX方法族:在当前的画图区域裁剪(clip)出一个新的画图

[ html canvas save restore ] canvas绘图 save restore 属性实例演示

解析: 我们可以在做平移变换之前将当前canvas的状态进行保存,其实Canvas为 我们提供了图层(Layer)的支持,而这些Layer(图层)是按"栈结构"来进行管理的 当我们调用save()方法,会保存当前Canvas的状态然后作为一个Layer(图层),添加到Canvas栈中, 另外,这个Layer(图层)不是一个具体的类,就是一个概念性的东西而已! 而当我们调用restore()方法的时候,会恢复之前Canvas的状态,而此时Canvas的图层栈 会弹出栈顶的那个Layer,

莫烦tensorflow(9)-Save&Restore

import tensorflow as tfimport numpy as np ##save to file#rember to define the same dtype and shape when restore# W = tf.Variable([[1,2,3],[3,4,5]],dtype=tf.float32,name='Weights')# b = tf.Variable([[1,2,3]],dtype=tf.float32,name='biases') # init = tf

Android-Canvas.save() Canvas.restore() 总结

相信很多人和我一样看了官方文档对Canvas save(), restore()方法的解释还是一个头雾水,save()保存的到底是什么信息呢? 答案是:坐标系的原点,坐标轴方向的信息. 我们在使用Canvas时难免会用到transitoin(), rotate()方法来改变坐标系的原点和坐标轴的方向,save()保存的正是这些信息. 下面举个栗子: 该例子用Canvas绘制一个仪表盘.自定义View,在onDraw()方法中绘制该仪表盘. 1 /** 2 * Created by Adminis

xen通过配置文件新建虚拟机

作为新手初学xen,兴致冲冲地在centos上源码安装了xen(安装过程可参见我的另一篇文章),现在到了新建虚拟机的过程了. 我搜了好些资料也没理出头绪,因为我觉得新建虚拟机不应该像这些资料里这么麻烦...于是各种google,大体总结出来一个步骤,与大家分享一下 当然,对于这种方式我也没有自信,有什么纠正的地方请各位大神斧正. 1,说明 首先,我在这里做一点说明,我希望创建的方式是通过xm create <配置文件>的半虚拟化的方式来新建虚拟机.主要考量是,感觉这种方式比较简便,而用图形工具

【起航计划 012】2015 起航计划 Android APIDemo的魔鬼步伐 11 App-&gt;Activity-&gt;Save &amp; Restore State onSaveInstanceState onRestoreInstanceState

Save & Restore State与之前的例子Android ApiDemo示例解析(9):App->Activity->Persistent State 实现的UI类似,但功能和实现方法稍有不同. (9)是通过Shared Preferences 和 Activity 的onPause() ,和onResume()来保持UI中 EditText 的值. 本例是通过onSaveInstanceState(Bundle savedBundle) 来实现保持UI状态. 和onPaus

KVM虚拟机快照链创建,合并,删除及回滚研究

1 QEMU,KVM,libvirt关系 QEMU QEMU提供了一个开源的服务器全虚拟化解决方案,它可以使你在特定平台的物理机上模拟出其它平台的处理器,比如在X86 CPU上虚拟出Power的CPU,此时的guest OS感觉不到虚拟机的存在,就像运行在物理机上,QEMU可以单独使用模拟CPU和各种外设,也可以作为一个用户空间工具和运行在内核中的KVM结合使用以充分发挥KVM的功能,QEMU的wiki KVM KVM是一个基于内核的虚拟机(Linux中一个可加载模块),在硬件支持虚拟化(int

GPU虚拟化技术

一.GPU概述 GPU的英文名称为Graphic Processing Unit,GPU中文全称为计算机图形处理器,由1999 年NVIDIA 公司提出.GPU这一概念也是相对于计算机系统中的CPU而言的,由于人们对图形的需求越来越大,尤其是在家用系统和游戏发烧友,而传统的CPU不能满足现状,因此需要提供一个专门处理图形的核心处理器.GPU 作为硬件显卡的"心脏",地位等同于CPU在计算机系统中的作用.同时GPU也可以用来作为区分2D硬件显卡和3D硬件显卡的重要依据.2D硬件显卡主要通