虚拟机迁移是指将正在运行的虚拟机实例从一个物理服务器(或主机)迁移到另一个物理服务器(或主机)的过程,而不会中断虚拟机的运行。
热迁移:开机状态下迁移
冷迁移:关机状态下迁移
1. 虚拟机的配置文件
2. 虚拟机的内存呢
3. 虚拟机的磁盘文件
虚拟机配置文件迁移就是从主机A将虚拟机的配置文件移动至主机B的过程
首先看配置文件,在执行迁移前,虚拟机的配置文件是在CNA03上的
迁移完成,再看虚拟机的配置文件已经不在CNA03上了

CNA02上可以看到该虚拟机的配置文件

内存迁移使用了写时重定向,流程如下(只考虑内存迁移,不考虑脏页等其他任何情况)

1. 迁移前虚拟机对内存的读写如图

2. 在迁移时,虚拟机的原宿主机会在内存中生成内存位图,并将原内存空间置为只读状态
3. 内存位图内保存了原内存空间的指针,后续虚拟机的所有读写都是往内存位图空间去读写,内存位图有点类似于ROW的快照空间
如图,此时虚拟机所有读写操作都是在内存位图所在内存上操作,通过内存位图中的指针来读取VM的原有数据,新数据全部写入到内存位图所在内存

4. 然后将这块只读的内存通过迁移网络迁移到目标宿主机

5. 多次迭代迁移
迭代迁移只需要迁移变化的内存就可以了,假设每100M内存迁移需要10秒,VM1占用内存为1000M,则迁移这1000M内存需要100秒,假设这100秒内又产生了200M的新内存,如果此时阻止上层IO下发并将这200M内存迁移到目标主机后运行,这过程中则需要终端2秒业务,所以需要多次迭代迁移,减小业务中断时间直至为无感知状态
6. 当最后一次迭代迁移的内存足够小时,系统立即阻止上层IO下发,最后一次同步内存数据到目标主机,并将虚拟机的配置文件迁移到目标主机
7. 虚拟机在目标主机上运行,迁移完成
为什么要存储热迁移

1. 虚拟机迁移不会影响业务,但会影响虚拟机性能,建议业务空闲时操作
2. 跨集群热迁移条件