虚拟机迁移的六个步骤原理

VMware vSphere vMotion功能是当今虚拟基础架构中最重偠的功能之一自2002年成立以及2003年发布以来,它允许我们将虚拟机的活动状态从一个物理ESXi主机迁移到另一个主机如今,无缝迁移虚拟机的能力几乎是每个虚拟化部署的重要组成部分工作负载的可移植性是真正的混合云体验的基础,能够使用在内部云和公共云之间移动它们vSphere vMotion仍然是IT行业中最重要的游戏改变者之一。

多年来vMotion内部开发了很多技术来支持新技术。

此博本文章将重点介绍标准vMotion这是将活动计算状態从源迁移到目标ESXi主机的标准vMotion。我们还可以执行Storage vMotion当与标准vMotion结合使用时,它被认为是增强vMotion其他类型的是长距离vMotion和跨集群vMotion,它们主要是vMotion进程的ESXi端之上的vCenter Server操作

启动虚拟机迁移的六个步骤后,vCenter Server实例将执行所谓的长时间运行的迁移任务以处理迁移第一步是执行兼容性检查。是否可以在目标主机上运行虚拟机考虑可能阻碍实时迁移的可能约束。接下来是告诉源和目标ESXi主机发生了什么创建包含以下信息的迁移任务:

  • 是否是正在迁移的虚拟机
  • 是否在配置该虚拟机(虚拟硬件,VM选项等)
  • 源ESXi主机是否符合要求
  • 目标ESXi主机是否符合要求

Agent(VPXA)VPXA侦听来自VPXD的消息,它接收迁移规范并通过hostd将其传递给VMX进程主机守护程序(hostd)维护特定于主机的信息和管理访问,包括VMstate等虚拟机遥测启动迁移时,hostd會将虚拟机置于中间状态以便在迁移期间无法更改其配置的虚拟机。

虚拟机监视器(VMM)进程负责管理虚拟机内存并将虚拟机存储和网IO请求传输到VMkernel所有其他对性能无关的IO请求都由VMM转发到VMX。虚拟机扩展(VMX)进程在VMkernel中运行负责处理对性能不重要的设备的IO。 请注意VMM仅在迁移期间在源ESXi主机上使用,因为这是虚拟机的活动内存所在的位置

完成此操作后,源ESXi上的VMkernel迁移模块将打开启用vMotion的网络上的套接字以设置与目标ESXi主机的通信。

到目前为止所有流程和通信路径都已准备好飞机票行实时迁移。准备阶段的目的是确保目标ESXi主机为要迁移的虚拟机预先分配计算资源此外,虚拟机已经在目标主机上被创建了但它处于被屏蔽状态。

完成准备阶段后该过程将进入预复制阶段,在此阶段将内存从源传输到目标ESXi主机需要跟踪源ESXi主机上的所有虚拟机内存页面。通过这样vMotion进程知道源虚拟机的哪些内存页面在迁移期间被覆蓋或修改(称为脏页面),因为它需要将这些内存页面重新发送到目标主机

在预复制阶段,虚拟机正在使用的vCPU会被短暂停顿以安装页媔跟踪器。VMkernel迁移模块现在要求VMM启动页面跟踪因为VMM拥有虚拟机的内存页表状态。下图显示了guest虚拟机操作系统在vMotion期间将数据写入内存时发生嘚情况:

页面跟踪是一个连续的循环它将通过使用多次迭代来实现内存预复制收敛。第一次迭代(预拷贝阶段-1)复制虚拟机内存以下迭代(预拷贝阶段0到n)用于复制脏内存页面。举个例子这就是我们实时迁移具有24GB内存的虚拟机时迭代的样子:

阶段-1:复制24GB的虚拟机内存囷跟踪页面。当我们发送内存时它会带来8GB的污染。
阶段0:重新传输脏污的8GB在这个过程中,内存污染另外3GB
阶段1:发送3GB。当转移发生时虚拟机又会污染1GB。
阶段2:发送剩余的1GB

当内存页面从源复制到目标ESXi主机时,我们需要确定何时能够完成预复制所以VMM会在每次迭代复制後询问VMkernel是否已完成预复制。当只有将所有内存更改(脏页)复制到目标主机时才可以执行后续操作。迭代内存预拷贝算法的一部分是将所有目标内存页面与其源匹配从第0页开始一直到最大或最后一个内存页码,依次检查所有内存页以查看目标页是否与源页同步

要确定峩们是否可以终止预复制,我们需要验证是否可以在<500ms的窗口中完成最后一次内存页面复制我们可以使用迁移开销中的信息来计算:

  • 迁移傳输速率; 以什么速度(GbE)我们在主机之间复制内存数据?
  • 脏页率(GB / s); 客户操作系统覆盖了多少内存页面
  • 我们还有多少页要传输到目标主機?

如果不是则发生下一次迭代。如果结果为是则VMkernel迁移模块将终止预复制过程。

现在如果脏页率高于迁移传输速率会发生什么?如果是这种情况那么进行另一次迭代是没有意义的,因为我们永远无法实现内存预复制的收敛并且迁移将停止。这就是我们在vSphere 5.0中引入Stun页媔发送(SDPS)的原因基本上,SDPS是VMkernel告诉VMM不运行预定指令但是引入非常短的“睡眠”的一种方式这可能听起来像是对工作负载性能的影响,泹这种情况发生在细粒度级别正是由于这些非常小的微秒级别的时间窗口,我们可以将vMotion预复制收敛并完成vMotion工作。

如果脏页面速率>传输速率则每次迭代执行SDPS。后续迭代仅复制在上一次迭代期间修改的脏内存页迭代的持续时间越短,客户OS就越不能修改或弄脏其存储页面从而缩短了下一次预复制迭代。虽然产生一些性能开销但SDPS通常不会对工作负载造成影响。这些开销对客户操作系统来说是可以忽略不計的

由VMM终止内存预复制后,所有内存页都驻留在目标ESXi主机上VMM现在向VMX发送远程过程调用(RPC),它可以挂起源虚拟机VMX将进入检查点阶段,暂停虚拟机并将检查点数据发送到目标ESXi主机

在此过程中,目标ESXi主机上的虚拟机将被解除屏蔽并使用源虚拟机的检查点数据恢复状态。基本流程是:启动目标虚拟机、中断启动过程、再把状态指向迁移过来的源虚拟机内存页完成启动。所有这些通常发生在100-200ms这是虚拟機处于不可访问的一个时间,这取决于主机硬件性能、动态的访问负载等各种因素

到此,虚拟机的vMotion完成

P2V 指迁移物理服务器上的操作系统忣其上的应用软件和数据到 VMM(Virtual Machine Monitor)管理的虚拟服务器中这种迁移方式,主要是使用各种工具软件把物理服务器上的系统状态和数据“镜潒”到 VMM 提供的虚拟机中,并且在虚拟机中“替换”物理服务器的存储硬件与网卡驱动程序只要在虚拟服务器中安装好相应的驱动程序并苴设置与原来服务器相同的地址(如 TCP/IP 地址等),在重启虚拟机服务器后虚拟服务器即可以替代物理服务器进行工作。

手动完成所有迁移操作需要对物理机系统和虚拟机环境非常了解。关闭原有的物理机上的服务和操作系统并且从其他媒质上启动一个新的系统。比如从 LiveCD 仩启动一个新的光盘系统大部分的发行版都会带有 LiveCD。把物理机系统的磁盘做成虚拟机镜像文件如有多个磁盘则需要做多个镜像,并且拷贝镜像到虚拟主机上为虚拟机创建虚拟设备,加载镜像文件启动虚拟机调整系统设置,并开启服务

利用专业工具辅助 P2V 的迁移,把某些手动环节进行自动化比如将物理机的磁盘数据转换成虚拟机格式,这一向是相当耗时的工作你可以选择专业的工具来完成这个步驟。这里有大量的工具可以使用如 RedHat 的开源工具 virt-p2v,Microsoft Virtual Server Migration Toolkit 等

迁移中避免宕机 。大部分 P2V 工具也有一个很大的限制:在整个迁移过程中物理机不鈳用。在运行关键任务的环境或有 SLA(服务水平协议)的地方这种工具不可选。幸运的是随着 P2V 技术的发展VMware vCenter Converter 和 Microsoft Hyper-V 已经能够提供热迁移功能,避免宕机目前,P2V 热迁移仅在 Windows 物理服务器可用未来将添加对

V2V 迁移是在虚拟机之间移动操作系统和数据,照顾主机级别的差异和处理不同嘚虚拟硬件虚拟机从一个物理机上的 VMM 迁移到另一个物理机的 VMM,这两个 VMM 的类型可以相同也可以不同。如 VMware 迁移到 KVM KVM 迁移到 KVM。可以通过多种方式将虚拟机从一个 VM Host 系统移动到另一个 VM Host 系统

也叫做常规迁移、静态迁移。在迁移之前将虚拟机暂停如果共享存储,则只拷贝系统状态臸目的主机最后在目的主机重建虚拟机状态,恢复执行如果使用本地存储,则需要同时拷贝虚拟机镜像和状态到目的主机到这种方式的迁移过程需要显示的停止虚拟机的运行。从用户角度看有明确的一段服务不可用的时间。这种迁移方式简单易行适用于对服务可鼡性要求不严格的场合。

又称为实时迁移 (live migration)是指在保证虚拟机上服务正常运行的同时,虚拟机在不同的物理主机之间进行迁移其逻辑步驟与离线迁移几乎完全一致。不同的是为了保证迁移过程中虚拟机服务的可用,迁移过程仅有非常短暂的停机时间迁移的前面阶段,垺务在源主机运行当迁移进行到一定阶段,目的主机已经具备了运行系统的必须资源经过一个非常短暂的切换,源主机将控制权转移箌目的主机服务在目的主机上继续运行。对于服务本身而言由于切换的时间非常短暂,用户感觉不到服务的中断因而迁移过程对用戶是透明的。在线迁移适用于对服务可用性要求很高的场景
另外,在某些没有使用共享存储的场合可以使用存储块在线迁移技术来实現 V2V 的虚拟机在线迁移。相比较基于共享存储的在线迁移数据块在线迁移的需要同时迁移虚拟机磁盘镜像和系统内存状态,迁移性能上打叻折扣但是他使得在采用分散式本地存储的环境下,仍然能够利用迁移技术转移计算机环境并且保证迁移过程中操作系统服务的可用性,扩展了虚拟机在线迁移的应用范围V2V 在线迁移技术消除了软硬件相关性,是进行软硬件系统升级维护等管理操作的有力工具。

对于 VM 嘚内存状态的迁移XEN 和 KVM 都采用了主流的的预拷贝(pre-copy)的策略。迁移开始之后源主机 VM 仍在运行,目的主机 VM 尚未启动迁移通过一个循环,將源主机 VM 的内存数据发送至目的主机 VM循环第一轮发送所有内存页数据,接下来的每一轮循环发送上一轮预拷贝过程中被 VM 写过的脏页内存 dirty pages直到时机成熟,预拷贝循环结束进入停机拷贝阶段,源主机被挂起不再有内存更新。最后一轮循环中的脏页被传输至目的主机 VM预拷贝机制极大的减少了停机拷贝阶段需要传输的内存数据量,从而将停机时间大大缩小
然而,对于更新速度非常快的内存部分每次循環过程都会变脏,需要重复 pre-copy同时也导致循环次数非常多,迁移的时间变长针对这种情况,KVM 虚拟机建立了三个原则:集中原则一个循環内的 dirty pages 小于等于 50;不扩散原则, 一个循环内传输的 dirty pages 少于新产生的;有限循环原则循环次数必须少于 30。在实现上就是采取了以下措施:

循环次数和效果受到控制,对每轮 pre-copy 的效果进行计算若 pre-copy 对于减少不一致内存数量的效果不显著,或者循环次数超过了上限循环将中止,進入停机拷贝阶段
在被迁移 VM 的内核设置一个内存访问的监控模块。在内存 pre-copy 过程中VM 的一个进程在一个被调度运行的期间,被限制最多执荇 40 次内存写操作这个措施直接限制了 pre-copy 过程中内存变脏的速度,其代价是对 VM 上的进程运行进行了一定的限制

V2P 指把一个操作系统、应用程序和数据从一个虚拟机中迁移到物理机的主硬盘上,是 P2V 的逆操作它可以同时迁移虚拟机系统到一台或多台物理机上。尽管虚拟化的基本需求是整合物理机到虚拟机中但这并不是虚拟化的唯一的应用。比如有时虚拟机上的应用程序的问题需要在物理机上验证以排除虚拟環境带来的影响。另外配置新的工作站是件令 IT 管理者头痛的事情,但虚拟化的应用可以帮助他解决这个难题先配置好虚拟机,然后运鼡硬盘克隆工具复制数据至工作站硬件比如赛门铁克的 Save & Restore (Ghost)。不过这种克隆方法有两个局限:一个镜像只能运用在同种硬件配置的机器上;偠想保存配置的修改只能重做新的镜像。
V2P 的迁移可以通过确定目标的物理环境来手动完成如把一个特定的硬盘加载到虚拟系统中,然後在虚拟环境中安装操作系统、应用程序和数据最后手动修改系统配置和驱动程序。这是一个乏味且不确定的过程特别是在新的环境仳旧的环境包含更多大量不同的硬件的情况下。为了简化操作我们可以利用专门的迁移工具以自动的方式来完成部分或全部迁移工作。目前支持 V2P 转换的工具有 PlateSpin Migrate 和 EMC HomeBase使用这样的工具使得 V2P 转换过程更简易,并且比使用第三方磁盘镜像工具更快捷

V2P 的不确定性导致自动化工具不哆,目前主要有以下几种解决方案:
基于备份和恢复操作系统的解决方案这个方案利用了现成的系统备份恢复工具,没有体现虚拟机和粅理机的差别类似于 P2P(Physical-to-Physical 物理机到物理机迁移)。注意备份工具能够恢复系统到异构硬件平台上
开源工具的解决方案。适合 Linux/Unix 系统使用開源工具和脚本,手动迁移系统这个方案难度较大,适合有经验的管理员

1、当你通过vCenter Server配置vSphere集群的时候集群中的Host会“选举”出1台“主机”,其余Host会遵循“主机”的调配

2、集群如果开启了HA功能,那么可以设定对Host和虚拟机的状态检测当系统发現某台Host或Guest发生故障没有响应的时候。“主机”会调度其他可用的Host接管这些Guest并重新启动它们。如果开启了集群的负载均衡功能(DRS)那么会選择负载最低的那一台Host来承载Guest


1、如果"主机"发生故障的时候,剩余的Host会重新进行选举
2、HA的前提是使用共享存储,并且Guest保存在共享存储中

我要回帖

更多关于 虚拟机迁移的六个步骤 的文章

 

随机推荐