CN116737324A - 硬件Virtio-net设备的热迁移方法、装置、设备及介质 - Google Patents

硬件Virtio-net设备的热迁移方法、装置、设备及介质 Download PDF

Info

Publication number
CN116737324A
CN116737324A CN202311014463.9A CN202311014463A CN116737324A CN 116737324 A CN116737324 A CN 116737324A CN 202311014463 A CN202311014463 A CN 202311014463A CN 116737324 A CN116737324 A CN 116737324A
Authority
CN
China
Prior art keywords
migrated
migration
hardware
data
virtual
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202311014463.9A
Other languages
English (en)
Other versions
CN116737324B (zh
Inventor
请求不公布姓名
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Wuxi Muchuang Integrated Circuit Design Co ltd
Original Assignee
Wuxi Muchuang Integrated Circuit Design Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Wuxi Muchuang Integrated Circuit Design Co ltd filed Critical Wuxi Muchuang Integrated Circuit Design Co ltd
Priority to CN202311014463.9A priority Critical patent/CN116737324B/zh
Publication of CN116737324A publication Critical patent/CN116737324A/zh
Application granted granted Critical
Publication of CN116737324B publication Critical patent/CN116737324B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Stored Programmes (AREA)

Abstract

本申请公开了一种硬件Virtio‑net设备的热迁移方法、装置、设备及介质,涉及云计算技术领域。应用于源宿主机,该方法包括:利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio‑net设备的迁移指令;根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio‑net设备对应的待迁移数据;将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio‑net设备。通过本申请的技术方案,可以实现硬件Virtio‑net设备的在线热迁移。

Description

硬件Virtio-net设备的热迁移方法、装置、设备及介质
技术领域
本发明涉及云计算技术领域,特别涉及一种硬件Virtio-net设备的热迁移方法、装置、设备及介质。
背景技术
在计算机虚拟化环境下,虚拟机的迁移已经成为了一个热门的研究领域。其中,在线热迁移是指在虚拟机运行时将其从一个宿主机迁移到另一个宿主机而不中断虚拟机的服务。Virtio-net作为在虚拟化环境中使用的虚拟网络设备模型,提供了一种高性能和低延迟的网络传输解决方案。当前,仅支持利用软件如利用虚拟机实现的软件Virtio-net设备的在线热迁移,而利用硬件实现的硬件Virtio-net设备,无法通过软件Virtio-net设备的在线热迁移过程进行迁移。目前的硬件Virtio-net设备在迁移时主要通过手动方式进行,并且也不是在线的实时迁移,其原因在于:硬件Virtio-net设备会被透传到虚拟机中,迁移程序无法感知硬件Virtio-net设备的状态,不知道何时启动迁移。
因此,如何提供一种解决上述技术问题的方案是本领域技术人员目前需要解决的问题。
发明内容
有鉴于此,本发明的目的在于提供一种硬件Virtio-net设备的热迁移方法、装置、设备及介质,能够支持硬件Virtio-net设备的在线热迁移。其具体方案如下:
第一方面,本申请公开了一种硬件Virtio-net设备的热迁移方法,应用于源宿主机,包括:
利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;
根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;
将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
可选的,所述利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令,包括:
利用虚拟操作系统模拟器对象模型获取通过Libvirt发出的针对待迁移硬件Virtio-net设备的迁移指令。
可选的,所述根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据,包括:
将所述迁移指令发送至物理功能驱动;
通过所述物理功能驱动通知虚拟功能驱动准备迁移,以便所述虚拟功能驱动停止响应,并保存所述待迁移硬件Virtio-net设备当前的执行状态上下文;
通过所述虚拟功能驱动向所述物理功能驱动发送可以开始执行迁移的标志,以便所述物理功能驱动根据所述可以开始执行迁移的标志通知固件开始迁移。
可选的,所述根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据,包括:
根据所述迁移指令通过网卡驱动通知固件开始迁移;
确定目标时间节点,并在所述目标时间节点获取与所述待迁移硬件Virtio-net设备对应的待迁移数据。
可选的,所述将所述待迁移数据迁移至目标宿主机,包括:
将所述待迁移数据存储至源宿主机内存;
通过所述热迁移组件从所述源宿主机内存中读取所述待迁移数据,并将所述待迁移数据迁移至目标宿主机。
可选的,所述将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备,包括:
将所述待迁移数据进行序列化,并将序列化后的待迁移数据发送至目标宿主机,以便所述目标宿主机对所述序列化后的待迁移数据进行反序列化,并根据反序列化后的所述待迁移数据启动所述待迁移硬件Virtio-net设备。
第二方面,本申请公开了一种硬件Virtio-net设备的热迁移方法,应用于目标宿主机,包括:
获取待迁移数据;其中,所述待迁移数据为根据迁移指令通过网卡驱动通知固件开始迁移后,获取的与待迁移硬件Virtio-net设备对应的数据;所述迁移指令为源宿主机利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取的针对所述待迁移硬件Virtio-net设备的指令;
根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
第三方面,本申请公开了一种硬件Virtio-net设备的热迁移装置,应用于源宿主机,包括:
指令获取模块,用于利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;
数据获取模块,用于根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;
数据迁移模块,用于将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
第四方面,本申请公开了一种电子设备,所述电子设备包括处理器和存储器;其中,所述存储器用于存储计算机程序,所述计算机程序由所述处理器加载并执行以实现如前所述的硬件Virtio-net设备的热迁移方法。
第五方面,本申请公开了一种计算机可读存储介质,用于存储计算机程序;其中所述计算机程序被处理器执行时实现如前所述的硬件Virtio-net设备的热迁移方法。
本申请提供了一种硬件Virtio-net设备的热迁移方法,应用于源宿主机,包括:利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。可见,本发明通过虚拟操作系统模拟器后端增加的热迁移组件,可以让硬件Virtio-net设备感知到热迁移的指令;进一步的,根据迁移指令通过网卡固件获取与待迁移硬件Virtio-net设备对应的待迁移数据,将待迁移数据迁移至目标宿主机;当目标宿主机根据待迁移数据启动所述待迁移硬件Virtio-net设备后,完成Virtio-net物理设备的在线热迁移。如此一来,实现一套Virtio-net物理设备的热迁移流程,提高了硬件Virtio-net设备热迁移的效率。
此外,本申请提供的一种硬件Virtio-net设备的热迁移装置、设备及存储介质,与上述硬件Virtio-net设备的热迁移方法对应,效果同上。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本申请公开的一种硬件Virtio-net设备的热迁移方法流程图;
图2为本申请公开的一种硬件Virtio-net设备的热迁移整体框架图;
图3为本申请公开的一种硬件Virtio-net设备的热迁移执行流程图;
图4为本申请公开的一种硬件Virtio-net设备的热迁移方法流程图;
图5为本申请公开的一种硬件Virtio-net设备的热迁移装置结构示意图;
图6为本申请公开的一种电子设备结构图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
Virtio是半虚拟化Hypervisor中位于设备之上的抽象层。Virtio-net是一种在虚拟化环境中使用的虚拟网络设备模型,它提供了一种高性能和低延迟的网络传输解决方案,并且支持热迁移(live migration)功能。热迁移是指在不中断虚拟机的情况下将其从一台物理主机迁移到另一台物理主机的过程。
下面是软件Virtio-net设备热迁移的基本流程:
1、虚拟机准备:在进行热迁移之前,需要确保虚拟机的操作系统和应用程序都支持Virtio-net设备,并且已经正确地配置和加载了Virtio驱动程序;
2、迁移准备:在准备进行热迁移之前,源主机和目标主机需要建立网络连接,并且通过共享存储或网络存储等方式,确保虚拟机的磁盘映像在目标主机上可访问;
3、冻结虚拟机:为了确保虚拟机在迁移过程中的一致性,需要在开始热迁移前冻结虚拟机。在冻结期间,源主机将停止将网络数据包发送到虚拟机,并确保虚拟机的内存状态不会发生变化;
4、内存迁移:源主机开始将虚拟机的内存内容逐页传输到目标主机。这涉及到将内存页复制到目标主机上的对应位置,并在复制完成后保持同步;
5、网络迁移:在内存迁移完成后,源主机将虚拟机的网络连接从源物理网络设备切换到目标物理网络设备。这可能涉及到在目标主机上重新配置网络设备,以确保虚拟机在目标主机上能够正常工作;
6、解冻虚拟机:在网络迁移完成后,虚拟机被解冻,并且可以继续处理网络数据包。
上述流程通过虚拟机实现是软件的一套方法,Virtio-net设备的热迁移实现通常依赖于虚拟化平台的特定功能和协议。例如,在基于KVM(Kernel-based Virtual Machine,基于内核的虚拟机)的虚拟化环境中,热迁移可以使用虚拟操作系统模拟器(QuickEmulator,QEMU)作为虚拟机监控程序。QEMU提供了用于控制虚拟机的管理接口,并通过与目标主机上的QEMU实例通信来协调热迁移过程。QEMU使用迁移日志(migration log)来记录虚拟机内存的变化,并通过网络通信将内存页传输到目标主机。
总的来说,Virtio-net设备的热迁移涉及到虚拟机内存的复制和同步以及网络连接的迁移和重配置,这样才可以使得虚拟机在迁移过程中的网络连接不中断,并且能够在目标主机上无缝继续运行。
然而,硬件实现的Virtio-net设备无法通过上述流程进行迁移,目前的硬件Virito-net设备迁移通过手动方式进行,而且不是在线的实时迁移。原因在于,硬件Virtio-net设备会被透传到虚拟机中,迁移程序无法感知硬件Virtio-net设备状态,不知道何时启动迁移。
为此,本申请提供了一种硬件Virtio-net设备的热迁移方案,通过增加的QEMU后端热迁移组件和固件程序,可以让Virtio-net设备感知到热迁移指令。
本发明实施例公开了一种硬件Virtio-net设备的热迁移方法,应用于源宿主机,参见图1所示,该方法包括:
步骤S11:利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令。
本申请实施例可以实现在虚拟机运行时将硬件Virtio-net设备从一个宿主机迁移到另一个宿主机上而不中断虚拟机的服务。具体实现时,系统包括源宿主机和目标宿主机,本申请实施例应用于源宿主机。
迁移开始的时候,通过Libvirt发出开始迁移的指令。可以理解的是,Libvirt是一种用于管理虚拟化平台的开源管理工具,可适用于多种虚拟化技术。当Libvirt发出针对待迁移硬件Virtio-net设备的迁移指令后,利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取该迁移指令。需要指出的是,预先在虚拟操作系统模拟器后端构建的热迁移组件为虚拟操作系统模拟器对象模型(QEMU Object Module,QOM),其中,增加了硬件Virtio-net设备相关的迁移管理程序。一方面可以接收来自Libvirt虚拟组件发出的迁移指令,另一方面可以和物理功能(Physical Function,PF)驱动进行通讯来进行迁移数据的传输。
步骤S12:根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据。
本申请实施例中,根据迁移指令通过网卡驱动告诉固件开始迁移,同时,在这个过程中获取待迁移硬件Virtio-net设备相关的待迁移数据。具体的,将所述迁移指令发送至物理功能驱动;通过所述物理功能驱动通知虚拟功能驱动准备迁移,以便所述虚拟功能驱动停止响应,并保存所述待迁移硬件Virtio-net设备当前的执行状态上下文;通过所述虚拟功能驱动向所述物理功能驱动发送可以开始执行迁移的标志,以便所述物理功能驱动根据所述可以开始执行迁移的标志通知固件开始迁移。
可见,构建的热迁移组件与PF驱动进行通讯,将迁移指令发送至PF驱动,通知PF驱动开始为迁移做准备。需要指出的是,PF驱动里面实现了一套迁移接口,一方面可以向上和热迁移组件进行通讯,接收传递的迁移指令;另一方面,PF驱动又管理着所有硬件Virtio-net设备,可以向下和网卡里面的固件进行沟通来传递迁移指令和传送迁移数据,如具体迁移哪个硬件Virtio-net设备的数据。
首先,PF驱动通知虚拟功能(Virtual Function,VF)驱动准备迁移;当VF驱动收到通知后停止所有请求,为迁移做准备;进一步的,VF驱动通知PF驱动迁移准备就绪,可以开始迁移,向PF驱动发送可以开始执行迁移的标志;然后PF驱动通知固件开始迁移,对待迁移数据打包,也即,对保存的待迁移硬件Virtio-net设备当前的执行状态上下文进行打包,然后放到源宿主机的host内存。其中,待迁移硬件Virtio-net设备当前的执行状态上下文可以是网卡的寄存器状态、队列上下文、中断状态以及内存中的数据等。
可以理解的是,由于虚拟机里面有很多调用(call)来执行网卡数据的操作,一些处理流程无法被打断,需要将当前指令对应的数据执行完之后才能响应迁移指令,然后把当前数据保存下来。可见,并不是在接收到迁移指令后就可以立即停止其他请求的,而需要进行判断:如果是可以打断的进程就立即停止下来;如果不可以打断,那么则会等当前执行操作完成之后再执行迁移指令并保存执行上下文。因此,固件接到迁移指令后,选择合适的时间节点终止当前指令的执行,保存执行上下文。也即,根据所述迁移指令通过网卡驱动通知固件开始迁移后,确定目标时间节点,在所述目标时间节点获取与所述待迁移硬件Virtio-net设备对应的待迁移数据。
步骤S13:将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
本申请实施例中,PF驱动通知固件开始迁移,固件对待迁移数据打包并放到源宿主机的host内存。这样,热迁移组件响应迁移指令后就可以从源宿主机内存中读取到待迁移数据,然后将待迁移数据发送到目的端,以将待迁移硬件Virtio-net设备迁移至目标宿主机。
需要指出的是,在将待迁移数据迁移至目标宿主机时,需要将所述待迁移数据进行序列化,并将序列化后的待迁移数据通过socket(套接字)接口发送至目标宿主机。同样的,目标宿主机执行数据的反序列化恢复上下文,并根据反序列化后的所述待迁移数据启动所述待迁移硬件Virtio-net设备,如此一来,可以实现从中断的位置继续执行硬件Virtio-net设备,完成迁移。
本申请提供了一种硬件Virtio-net设备的热迁移方法,应用于源宿主机,包括:利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。可见,本发明通过虚拟操作系统模拟器后端增加的热迁移组件,可以让硬件Virtio-net设备感知到热迁移的指令;进一步的,根据迁移指令通过网卡固件获取与待迁移硬件Virtio-net设备对应的待迁移数据;将待迁移数据迁移至目标宿主机,当目标宿主机根据待迁移数据启动所述待迁移硬件Virtio-net设备后,完成Virtio-net物理设备的在线热迁移。如此一来,实现一套Virtio-net物理设备的热迁移流程,提高了硬件Virtio-net设备热迁移的效率。
如图2所示为本发明的整体架构图。在进行在线热迁移时,首先需要在源宿主机上获取待迁移硬件Virtio-net设备的信息,然后将待迁移的硬件Virtio-net设备与源宿主机解除绑定并将其状态保存。接着将待迁移硬件Virtio-net设备的状态发送给目标宿主机。在目标宿主机上,需要接收待迁移硬件Virtio-net设备的状态并将其绑定到目标宿主机上。在源宿主机上需要关闭待迁移Virtio-net设备并将其删除。在目标宿主机上,需要启动待迁移硬件Virtio-net设备,完成在线热迁移过程。
在图2示例性展示的整体架构图中,包括智能网卡上的固件程序、QEMU后端构建的热迁移组件以及网卡驱动。网卡SoC(System on Chip,系统级芯片)上运行Virtio的管理进程,Virtio作为通用的IO(Input/Output,输入/输出)虚拟化模型,每个Virtio设备会对应一个具体的Virtio例程,包括基于Virtio的网络设备Virtio-net和块存储设备Virtio-blk。热迁移进程同样运行在SoC用户空间。此外在host端会加载网卡对应的驱动程序,QEMU后端增加Virtio的迁移管理程序。迁移开始的时候,Libvirt发出开始迁移的指令,并通过网卡驱动告诉固件开始迁移。固件接到迁移指令后,选择合适的时间节点终止当前指令的执行,保存执行上下文并将迁移数据序列化,通过socket接口发到目的端,同样目的端执行数据的反序列化,并恢复上下文,并从中断的点继续执行。
可以理解的是,虚拟机是一个真实的物理机的仿真,在云端客户使用的或接收到的都是这种虚拟机,硬件Virtio-net设备则是一个真实的物理的Virtio-net设备,如图3所示即为在虚拟的环境里面,如何通过网卡对应的驱动程序与Qemu后端增加Virtio的迁移管理程序协同实现迁移一个真实的硬件Virtio-net设备的流程。
(1)Libvirt发出迁移指令;
(2)Virtio QOM(虚拟操作系统模拟器对象模型)获取Libvirt发出的迁移指令并通知PF(物理功能)驱动开始准备迁移;
(3)PF驱动通知VF(虚拟功能)驱动启动迁移;
(4)VF收到迁移指令后停止所有请求;
(5)VF驱动通知PF驱动迁移准备就绪,等待固件迁移数据;
(6)PF驱动通知固件开始传递待迁移数据;
(7)固件开始序列化并打包数据,传递待迁移数据给PF驱动放到内存;
(8)QOM驱动读取待迁移数据;
(9)通过网络发送待迁移数据。
综上,通过增加的支持热迁移的固件和QEMU后端的热迁移组件以及一套迁移流程,可以实现硬件Virtio-net设备的在线热迁移。
本申请实施例公开了一种硬件Virtio-net设备的热迁移方法,应用于目标宿主机,参见图4所示,该方法包括:
步骤S21:获取待迁移数据;其中,所述待迁移数据为根据迁移指令通过网卡驱动通知固件开始迁移后,获取的与待迁移硬件Virtio-net设备对应的数据;所述迁移指令为源宿主机利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取的针对所述待迁移硬件Virtio-net设备的指令。
步骤S22:根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
其中,关于上述步骤S21、步骤S22更加具体的处理过程可以参考前述实施例中公开的相应内容,在此不再进行赘述。
本申请提供了一种硬件Virtio-net设备的热迁移方法,应用于目标宿主机,包括:获取待迁移数据;其中,所述待迁移数据为根据迁移指令通过网卡驱动通知固件开始迁移后,获取的与待迁移硬件Virtio-net设备对应的数据;所述迁移指令为源宿主机利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取的针对所述待迁移硬件Virtio-net设备的指令;根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。可见,本发明通过虚拟操作系统模拟器后端增加的热迁移组件,可以让硬件Virtio-net设备感知到热迁移的指令;进一步的,根据迁移指令通过网卡固件获取与待迁移硬件Virtio-net设备对应的待迁移数据;将待迁移数据迁移至目标宿主机,当目标宿主机根据待迁移数据启动所述待迁移硬件Virtio-net设备后,完成Virtio-net物理设备的在线热迁移。如此一来,实现一套Virtio-net物理设备的热迁移流程,提高了硬件Virtio-net设备热迁移的效率。
相应的,本申请实施例还公开了一种硬件Virtio-net设备的热迁移装置,应用于源宿主机,参见图5所示,该装置包括:
指令获取模块11,用于利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;
数据获取模块12,用于根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;
数据迁移模块13,用于将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
其中,关于上述各个模块更加具体的工作过程可以参考前述实施例中公开的相应内容,在此不再进行赘述。
由此可见,通过本实施例的上述方案,应用于源宿主机,包括:利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。可见,本发明通过虚拟操作系统模拟器后端增加的热迁移组件,可以让硬件Virtio-net设备感知到热迁移的指令;进一步的,根据迁移指令通过网卡固件获取与待迁移硬件Virtio-net设备对应的待迁移数据;将待迁移数据迁移至目标宿主机,当目标宿主机根据待迁移数据启动所述待迁移硬件Virtio-net设备后,完成Virtio-net物理设备的在线热迁移。如此一来,实现一套Virtio-net物理设备的热迁移流程,提高了硬件Virtio-net设备热迁移的效率。
进一步的,本申请实施例还公开了一种电子设备,图6是根据一示例性实施例示出的电子设备20结构图,图中内容不能认为是对本申请的使用范围的任何限制。
图6为本申请实施例提供的一种电子设备20的结构示意图。该电子设备20,具体可以包括:至少一个处理器21、至少一个存储器22、电源23、通信接口24、输入输出接口25和通信总线26。其中,所述存储器22用于存储计算机程序,所述计算机程序由所述处理器21加载并执行,以实现前述任一实施例公开的硬件Virtio-net设备的热迁移方法中的相关步骤。另外,本实施例中的电子设备20具体可以为计算机。
本实施例中,电源23用于为电子设备20上的各硬件设备提供工作电压;通信接口24能够为电子设备20创建与外界设备之间的数据传输通道,其所遵循的通信协议是能够适用于本申请技术方案的任意通信协议,在此不对其进行具体限定;输入输出接口25,用于获取外界输入数据或向外界输出数据,其具体的接口类型可以根据具体应用需要进行选取,在此不进行具体限定。
另外,存储器22作为资源存储的载体,可以是只读存储器、随机存储器、磁盘或者光盘等,其上所存储的资源可以包括操作系统221、计算机程序222及数据223等,数据223可以包括各种各样的数据。存储方式可以是短暂存储或者永久存储。
其中,操作系统221用于管理与控制电子设备20上的各硬件设备以及计算机程序222,其可以是Windows Server、Netware、Unix、Linux等。计算机程序222除了包括能够用于完成前述任一实施例公开的由电子设备20执行的硬件Virtio-net设备的热迁移方法的计算机程序之外,还可以进一步包括能够用于完成其他特定工作的计算机程序。
进一步的,本申请实施例还公开了一种计算机可读存储介质,这里所说的计算机可读存储介质包括随机存取存储器(Random Access Memory,RAM)、内存、只读存储器(Read-Only Memory,ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、磁碟或者光盘或技术领域内所公知的任意其他形式的存储介质。其中,所述计算机程序被处理器执行时实现前述硬件Virtio-net设备的热迁移方法。关于该方法的具体步骤可以参考前述实施例中公开的相应内容,在此不再进行赘述。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
结合本文中所公开的实施例描述的硬件Virtio-net设备的热迁移方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上对本发明所提供的一种硬件Virtio-net设备的热迁移方法、装置、设备及介质进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (10)

1.一种硬件Virtio-net设备的热迁移方法,其特征在于,应用于源宿主机,包括:
利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;
根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;
将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
2.根据权利要求1所述的硬件Virtio-net设备的热迁移方法,其特征在于,所述利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令,包括:
利用虚拟操作系统模拟器对象模型获取通过Libvirt发出的针对待迁移硬件Virtio-net设备的迁移指令。
3.根据权利要求1所述的硬件Virtio-net设备的热迁移方法,其特征在于,所述根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据,包括:
将所述迁移指令发送至物理功能驱动;
通过所述物理功能驱动通知虚拟功能驱动准备迁移,以便所述虚拟功能驱动停止响应,并保存所述待迁移硬件Virtio-net设备当前的执行状态上下文;
通过所述虚拟功能驱动向所述物理功能驱动发送可以开始执行迁移的标志,以便所述物理功能驱动根据所述可以开始执行迁移的标志通知固件开始迁移。
4.根据权利要求1所述的硬件Virtio-net设备的热迁移方法,其特征在于,所述根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据,包括:
根据所述迁移指令通过网卡驱动通知固件开始迁移;
确定目标时间节点,并在所述目标时间节点获取与所述待迁移硬件Virtio-net设备对应的待迁移数据。
5.根据权利要求1所述的硬件Virtio-net设备的热迁移方法,其特征在于,所述将所述待迁移数据迁移至目标宿主机,包括:
将所述待迁移数据存储至源宿主机内存;
通过所述热迁移组件从所述源宿主机内存中读取所述待迁移数据,并将所述待迁移数据迁移至目标宿主机。
6.根据权利要求1至5任一项所述的硬件Virtio-net设备的热迁移方法,其特征在于,所述将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备,包括:
将所述待迁移数据进行序列化,并将序列化后的待迁移数据发送至目标宿主机,以便所述目标宿主机对所述序列化后的待迁移数据进行反序列化,并根据反序列化后的所述待迁移数据启动所述待迁移硬件Virtio-net设备。
7.一种硬件Virtio-net设备的热迁移方法,其特征在于,应用于目标宿主机,包括:
获取待迁移数据;其中,所述待迁移数据为根据迁移指令通过网卡驱动通知固件开始迁移后,获取的与待迁移硬件Virtio-net设备对应的数据;所述迁移指令为源宿主机利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取的针对所述待迁移硬件Virtio-net设备的指令;
根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
8.一种硬件Virtio-net设备的热迁移装置,其特征在于,应用于源宿主机,包括:
指令获取模块,用于利用预先在虚拟操作系统模拟器后端构建的热迁移组件获取针对待迁移硬件Virtio-net设备的迁移指令;
数据获取模块,用于根据所述迁移指令通过网卡驱动通知固件开始迁移,并获取与所述待迁移硬件Virtio-net设备对应的待迁移数据;
数据迁移模块,用于将所述待迁移数据迁移至目标宿主机,以便所述目标宿主机根据所述待迁移数据启动所述待迁移硬件Virtio-net设备。
9.一种电子设备,其特征在于,所述电子设备包括处理器和存储器;其中,所述存储器用于存储计算机程序,所述计算机程序由所述处理器加载并执行以实现如权利要求1至7任一项所述的硬件Virtio-net设备的热迁移方法。
10.一种计算机可读存储介质,其特征在于,用于存储计算机程序;其中所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的硬件Virtio-net设备的热迁移方法。
CN202311014463.9A 2023-08-14 2023-08-14 硬件Virtio-net设备的热迁移方法、装置、设备及介质 Active CN116737324B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311014463.9A CN116737324B (zh) 2023-08-14 2023-08-14 硬件Virtio-net设备的热迁移方法、装置、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311014463.9A CN116737324B (zh) 2023-08-14 2023-08-14 硬件Virtio-net设备的热迁移方法、装置、设备及介质

Publications (2)

Publication Number Publication Date
CN116737324A true CN116737324A (zh) 2023-09-12
CN116737324B CN116737324B (zh) 2023-11-03

Family

ID=87906423

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311014463.9A Active CN116737324B (zh) 2023-08-14 2023-08-14 硬件Virtio-net设备的热迁移方法、装置、设备及介质

Country Status (1)

Country Link
CN (1) CN116737324B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116932433A (zh) * 2023-09-18 2023-10-24 珠海星云智联科技有限公司 基于dpu的装机控制方法及相关设备

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20170322828A1 (en) * 2016-05-09 2017-11-09 Cavium, Inc. Systems and methods for virtio based optimization of data packet paths between a virtual machine and a network device for live virtual machine migration
CN112306650A (zh) * 2019-07-31 2021-02-02 华为技术有限公司 虚拟机热迁移方法和通信设备
CN115390996A (zh) * 2022-10-28 2022-11-25 安超云软件有限公司 虚拟机迁移方法和装置、计算设备和存储介质
CN115913953A (zh) * 2022-11-04 2023-04-04 陕西浪潮英信科技有限公司 一种云资源加速方法、装置及其介质
CN116302337A (zh) * 2023-02-27 2023-06-23 阿里巴巴(中国)有限公司 虚拟机迁移方法、设备及存储介质

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20170322828A1 (en) * 2016-05-09 2017-11-09 Cavium, Inc. Systems and methods for virtio based optimization of data packet paths between a virtual machine and a network device for live virtual machine migration
CN112306650A (zh) * 2019-07-31 2021-02-02 华为技术有限公司 虚拟机热迁移方法和通信设备
CN115390996A (zh) * 2022-10-28 2022-11-25 安超云软件有限公司 虚拟机迁移方法和装置、计算设备和存储介质
CN115913953A (zh) * 2022-11-04 2023-04-04 陕西浪潮英信科技有限公司 一种云资源加速方法、装置及其介质
CN116302337A (zh) * 2023-02-27 2023-06-23 阿里巴巴(中国)有限公司 虚拟机迁移方法、设备及存储介质

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
JAMES张: "智能网卡如何做到快速有效的支持热迁移", pages 1 - 5, Retrieved from the Internet <URL:https://aijishu.com/a/1060000000222774> *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116932433A (zh) * 2023-09-18 2023-10-24 珠海星云智联科技有限公司 基于dpu的装机控制方法及相关设备
CN116932433B (zh) * 2023-09-18 2024-01-09 珠海星云智联科技有限公司 基于dpu的装机控制方法及相关设备

Also Published As

Publication number Publication date
CN116737324B (zh) 2023-11-03

Similar Documents

Publication Publication Date Title
US9996396B2 (en) Cross architecture virtual machine migration
US10417174B2 (en) Remote direct memory access in a virtualized computing environment
EP2835953B1 (en) System for live migration of virtual machine
US9197489B1 (en) Live migration of virtual machines in a hybrid network environment
US7484208B1 (en) Virtual machine migration
US9811367B2 (en) Method and apparatus for combined hardware/software VM migration
US20190235904A1 (en) Cloning services in virtualized computing systems
US9928107B1 (en) Fast IP migration in a hybrid network environment
US20120054264A1 (en) Techniques for Migrating Active I/O Connections with Migrating Servers and Clients
US20110153715A1 (en) Lightweight service migration
US8909912B2 (en) Apparatus and method for configuring a target machine with captured operational state comprising a static machine profile and a dynamic machine state to continue operations of a source machine
CN116737324B (zh) 硬件Virtio-net设备的热迁移方法、装置、设备及介质
AU2014226355A1 (en) Method and system for providing a roaming remote desktop
CN113312143A (zh) 云计算系统、命令处理方法及虚拟化仿真装置
CN103077034B (zh) 混合虚拟化平台java应用迁移方法与系统
WO2022143714A1 (zh) 服务器系统、虚拟机创建方法及装置
WO2012128744A1 (en) Sharing internet capability of a mobile computing device with a client computing device using a virtual machine
KR20130051820A (ko) 모바일 환경에서의 소프트웨어 마이그레이션 장치 및 방법
Kooburat et al. The Best of Both Worlds with {On-Demand} Virtualization
WO2020192448A1 (zh) 虚拟机的迁移方法和系统
CN107949828B (zh) 用于将应用中的机器代码的执行动态地迁移至虚拟机的方法和装置
CN113242175B (zh) 一种基于spdk的存储网关及其实现方法
Kumar et al. Netchannel: a VMM-level mechanism for continuous, transparentdevice access during VM migration
US11216211B1 (en) Emulated block storage for devices
US11055115B1 (en) Virtual machine conversion in distributed system of remote desktops

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant