CN103685256A - 一种虚拟机迁移管理方法、装置及系统 - Google Patents

一种虚拟机迁移管理方法、装置及系统 Download PDF

Info

Publication number
CN103685256A
CN103685256A CN201310656235.1A CN201310656235A CN103685256A CN 103685256 A CN103685256 A CN 103685256A CN 201310656235 A CN201310656235 A CN 201310656235A CN 103685256 A CN103685256 A CN 103685256A
Authority
CN
China
Prior art keywords
virtual machine
computing node
migrated
transit time
migration
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
CN201310656235.1A
Other languages
English (en)
Other versions
CN103685256B (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.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies 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 Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Priority to CN201310656235.1A priority Critical patent/CN103685256B/zh
Publication of CN103685256A publication Critical patent/CN103685256A/zh
Priority to PCT/CN2014/083869 priority patent/WO2015081717A1/zh
Priority to KR1020167008845A priority patent/KR101814560B1/ko
Priority to JP2016519928A priority patent/JP6168576B2/ja
Priority to EP14795536.3A priority patent/EP2894827B1/en
Priority to US14/557,994 priority patent/US9720728B2/en
Application granted granted Critical
Publication of CN103685256B publication Critical patent/CN103685256B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/4557Distribution of virtual machine instances; Migration and load balancing

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Computer And Data Communications (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明实施例公开了一种虚拟机迁移管理方法,所述方法包括:根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。本发明实施例还公开了一种虚拟机迁移管理装置和系统。采用本发明,能够一定程度上提高虚拟机迁移决策的准确性。

Description

一种虚拟机迁移管理方法、装置及系统
技术领域
本发明涉及计算机技术领域,尤其涉及一种虚拟机迁移管理方法、装置及系统。
背景技术
虚拟机热迁移是虚拟化领域的一项关键技术,是实现虚拟化集群动态资源调度、不中断业务更换和维护主机的重要手段。虚拟机热迁移的基本原理是:在不影响用户业务或用户不感知的情况下,将运行的虚拟机从源物理机迁移到目标物理机。为了快速解决资源热点以及电源整合,每次可能需要决定迁移多个虚拟机,当前的策略是根据主机并发迁移虚拟机数目并结合历史虚拟机迁移时间的平均值进行计算每台主机最多容纳虚拟机迁移数目,而虚拟机的规格和业务的不同导致迁移时间的偏差较大,因此对迁移时间的评估不准确,无法做出合理的虚拟机热迁移决策。
发明内容
有鉴于此,本发明实施例提供一种虚拟机迁移管理方法、装置及系统,可通过动态计算虚拟机迁移时间,一定程度上提高虚拟机迁移决策的准确性。
为了解决上述技术问题,本发明实施例第一方面提供了一种虚拟机迁移管理方法,所述方法包括:
根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;
分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;
若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
在第一方面的第一种可能实现方式中,所述方法还包括:
在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。
在第一方面的第二种可能实现方式中,所述根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。
在第一方面的第三种可能实现方式中,所述根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
结合第一方面以及第一方面的第一至第三种可能实现方式,在第一方面的第四种可能实现方式中,所述方法还包括:
在每轮资源调度开始时初始化所有计算节点的可用迁移时间MTi=Ni×T,其中Ni为对应计算节点支持的并发迁移虚拟机数目,T为资源调度周期。
结合第一方面的第四种可能实现方式,在第一方面的第五种可能实现方式中,若在每轮资源调度开始时检测到计算节点正在进行虚拟机迁移,则初始化所述计算节点的可迁移时间MTi=Ni×T-MTVij,其中MTVij为该计算节点中正在进行迁移的虚拟机的迁移时间。
相应的,本发明实施例第二方面提供了一种虚拟机迁移管理装置,包括:
迁移时间计算模块,用于根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;
可迁移时间管理模块,用于分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;
迁移判断模块,用于若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
在第二方面的第一种可能实现方式中,所述可迁移时间管理模块还用于:
在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。
在第二方面的第二种可能实现方式中,所述迁移时间计算模块计算迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。
在第一方面的第三种可能实现方式中,所述迁移时间计算模块计算迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
结合第二方面以及第二方面的第一至第三种可能实现方式,所述可迁移时间管理模块还用于:
在每轮资源调度开始时初始化所有计算节点的可用迁移时间MTi=Ni×T,其中Ni为对应计算节点支持的并发迁移虚拟机数目,T为资源调度周期。
结合第二方面的第四种可能实现方式,在第二方面的第五种可能实现方式中,所述可迁移时间管理模块还用于:
若在每轮资源调度开始时检测到计算节点正在进行虚拟机迁移,则初始化所述计算节点的可迁移时间MTi=Ni×T-MTVij,其中MTVij为该计算节点中正在进行迁移的虚拟机的迁移时间。
相应的,本发明实施例第三方面还提供了一种虚拟机迁移管理系统,包括至少两个承载虚拟机的计算节点设备和如本发明实施例第二方面所述的任意一种虚拟机迁移管理装置。
相应的,本发明实施例第四方面还提供了一种虚拟机迁移管理系统,包括承载有至少一个待迁移虚拟机的源计算节点、目的计算节点,以及虚拟机迁移管理装置,
所述虚拟机迁移管理装置用于根据所述待迁移虚拟机的迁移参数计算所述待迁移虚拟机从所述源计算节点迁移至所述目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
在本发明实施例第四方面第一种可能的实现方式中,所述迁移时间可以通过以下两种中的任意一种实现方式计算获得:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,以及
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
本发明实施例通过待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,一定程度上提高了虚拟机迁移决策的准确性。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例中一种虚拟机迁移管理方法的流程示意图;
图2是本发明另一实施例中的虚拟机迁移管理方法的流程示意图;
图3是本发明实施例中的虚拟机迁移管理装置的结构示意图;
图4是本发明另一实施例中的虚拟机迁移管理装置的结构示意图;
图5是本发明实施例中的一种虚拟机迁移管理系统的结构示意图;
图6是本发明另一实施例中的虚拟机迁移管理系统的结构示意图;
图7是本发明实施例中提及的分布式资源管理系统的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明实施例中的虚拟机迁移管理方法可以由虚拟机迁移管理装置完成,所述虚拟机迁移管理装置可以实现在独立的节点设备中,也可以实现在如图7所示的分布式资源管理系统的管理节点设备中,图7所示的分布式资源管理系统中包括管理节点设备和多个计算节点,其中多个计算节点可以汇聚成节点簇,在节点簇中还可以设定主节点Master和从属节点Slave。
图1是本发明实施例中的一种虚拟机迁移管理方法的流程示意图,如图所示本实施例中的虚拟机迁移管理方法至少可以包括:
S101,根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽。
以预拷贝方式进行虚拟机迁移为例,虚拟机迁移管理装置可以根据负载均衡等因素决策需要从计算节点i迁移至计算节点j的虚拟机Vij,即待迁移虚拟机,进而获取该待迁移虚拟机的上层的业务QoS(Quality of Service,服务质量保证)为其限定的内存改变速率MCRVij以及下层的网络QoS为其限定的迁移网络带宽BWVij,进而迁移时间的推导过程可以如下:
第1轮拷贝,设源计算节点分配给虚拟机Vij的内存为MVij,在本实施例中称之为分配内存。将虚拟机Vij的分配内存MVij从源计算节点i传输到目的计算节点j,时间消耗为:
t0=MVij/BWVij;(示例性的MVij单位可以为Mb,BWVij单位可以为Mb/s)
第2轮拷贝,在第1轮拷贝的时间t0内,虚拟机Vij的分配内存有t0×MVij×MCRVij被改变掉,需要把这部分内存再从源计算节点i传输到目的计算节点j,时间消耗为
t1=t0×MVij×MCRVij/BWVij=MCRVij×(MVij/BWVij)2
第3轮,在第2轮拷贝的时间t1内,虚拟机Vij的分配内存有t1×MVij×MCRVij被改变掉,需要把这部分内存再从源计算节点i传输到目的计算节点j,时间消耗为:
t2=t1×MVij×MCRVij/BWVij=(MCRVij)2×(MVij/BWVij)3
以此类推,最终迁移时间应该为:
MTVij=t0+t1+t2+......+tn-1
=MVij/BWVij+MCRVij×(MVij/BWVij)2+......+(MCRVij)n-1×(MVij/BWVij)n设a0=MVij/BWVij,q=MCRVij×(MVij/BWVij),通常情况下,通过设置MCRVij和BWVij可以保证q是小于1的,所以上式是收敛的,则上述等式进一步化简为:
MTVij=a0+a0×q1+......+a0×qn-1=a0(1-qn)/(1-q)...................公式(1)
其中n为传输总次(轮)数,n=min{N0,N},其中N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值X的最小整数值,内存脏页即每轮拷贝传输过程中发生变化的内存页,内存脏页阈值X是一个内存脏页的数量值,可以预先由管理员设定,也就是说当某一轮拷贝的内存脏页数量小于该内存脏页阈值时,可以停止拷贝。
而在可选实施例中,可以采用先对虚拟机内存进行压缩再拷贝的方式进行虚拟机迁移,根据采用的压缩算法可以确定内存压缩比CVij,进而公式(1)可以调整为:
迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,n的确定方式与前文相同。
S102,分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间。
具体的,可以为每个计算节点设置一个可用迁移时间,即在每个调度周期该计算节点可以用以虚拟机迁移的时间。例如在每隔一定周期或者有典型事件(例如添加/删除计算节点到虚拟资源集群中、启动/关闭虚拟机等)触发资源调度时初始化每个计算节点的可用迁移时间,进而随着计算节点上发生的影响该可用迁移时间的典型事件(例如将原先运行在自身计算节点的虚拟机迁移至别的计算节点,或将原本运行在其他计算节点的虚拟机迁移至自身计算节点等)可以对该计算节点上的可用迁移时间进行更新,虚拟机迁移管理装置可以在决策需要从计算节点i迁移至计算节点j的虚拟机Vij后,分别获取源计算节点即计算节点i当前的可用迁移时间和目的计算节点即计算节点j当前的可用迁移时间。
S103,若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
即将S101中计算得到的所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间分别与源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间进行比较,若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点;若所述源计算节点当前的可用迁移时间小于所述迁移时间或所述目的计算节点当前的可用迁移时间均小于所述迁移时间,则确定所述待迁移虚拟机不可以从源计算节点迁移至目的计算节点。
在可选实施例中,在确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,虚拟机迁移管理装置可以向所述源计算节点和目的计算节点分别下发虚拟机迁移指令,以使其开始进行所述待迁移虚拟机的虚拟机迁移,与此同时将所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去所述迁移时间,使得下一次需要进行虚拟机迁移时可以根据更新后的可用迁移时间确定是否可以进行虚拟机迁移,从而实现了动态的对虚拟机迁移进行决策。对虚拟机迁移以实现对对应计算节点的可用迁移时间的准确管理,。
而在其他可选实施例中,虚拟机迁移管理装置也可以待所述待迁移虚拟机的迁移完成后,在所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去本次迁移的实际迁移时间,从而可以实现对计算节点的可用迁移时间更为准确的管理。
可见,本实施例结合图1所描述的虚拟机迁移管理方法可以根据待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,可以对于计算节点的虚拟机并发迁移数量进行动态管理,实现了更为准确的对虚拟机迁移进行决策。
图2是本发明另一实施例中的虚拟机迁移管理方法的流程示意图,如图所示本实施例中的虚拟机迁移管理方法可以包括:
S201,在每轮资源调度开始时初始化所有计算节点的可用迁移时间。
具体实现中,所述计算节点i的可用迁移时间可以初始化为MTi=Ni×T,其中Ni为计算节点i允许的并发迁移虚拟机数目,T为资源调度周期。
在可选实施例中,在初始化各计算节点的可用迁移时间时,可以检测各计算节点当前是否正在进行虚拟机迁移,若当前计算节点i正在进行向计算节点j的虚拟机Vij的迁移,则可以将计算节点i的可用迁移时间初始化为MTi=Ni×T-MTVij,MTVij为根据待迁移虚拟机Vij的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽,具体计算迁移时间的方式前文实施例中已详细举例,本实施例中不再赘述。
S202,根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽。
具体的,虚拟机迁移管理装置可以根据负载均衡等因素决策需要从计算节点i迁移至计算节点j的虚拟机Vij,即待迁移虚拟机,进而获取该待迁移虚拟机的上层的业务QoS(Quality of Service,服务质量保证)为其限定的内存改变速率MCRVij以及下层的网络QoS为其限定的迁移网络带宽BWVij,进而可以计算虚拟机Vij从计算节点i迁移至计算节点j的迁移时间MTVij,具体的计算方法可以参考前文实施例中的步骤S101,本实施例中不再赘述。
S203,分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间。
S204,若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
即将S202中计算得到的所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间分别与源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间进行比较,若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点;若所述源计算节点当前的可用迁移时间小于所述迁移时间或所述目的计算节点当前的可用迁移时间均小于所述迁移时间,则确定所述待迁移虚拟机不可以从源计算节点迁移至目的计算节点。
S205,在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。
具体实现中,在确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,虚拟机迁移管理装置可以向所述源计算节点和目的计算节点分别下发虚拟机迁移指令,以使其开始进行所述待迁移虚拟机的虚拟机迁移,并将所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去所述迁移时间。而在其他可选实施例中,虚拟机迁移管理装置也可以待所述待迁移虚拟机的迁移完成后,在所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去本次迁移的实际迁移时间。
可见,本实施例结合图2所描述的虚拟机迁移管理方法可以根据待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,可以对于计算节点的虚拟机并发迁移数量进行动态管理,实现了更为准确的对虚拟机迁移进行决策。
图3是本发明实施例提供的一种虚拟机迁移管理装置的结构示意图,本发明的虚拟机迁移管理装置可以实现在分布式资源管理系统的管理节点设备中,也可以实现在其他独立的节点设备中。如图所示本实施例中的虚拟机迁移装置可以包括:
迁移时间计算模块310,用于根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽。
具体实现中,以预拷贝方式进行虚拟机迁移为例,虚拟机迁移管理装置可以根据负载均衡等因素决策需要从计算节点i迁移至计算节点j的虚拟机Vij,即待迁移虚拟机,进而获取该待迁移虚拟机的上层的业务QoS(Quality of Service,服务质量保证)为其限定的内存改变速率MCRVij以及下层的网络QoS为其限定的迁移网络带宽BWVij,进而迁移时间计算模块310计算可以根据公式(1)计算迁移时间:
MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。具体迁移时间的计算推导过程前文实施例中已详细阐述,本实施例中不再赘述。
而在可选实施例中,可以采用先对虚拟机内存进行压缩再拷贝的方式进行虚拟机迁移,根据采用的压缩算法可以确定内存压缩比CVij,进而公式(1)可以调整为:
迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,n的确定方式与前文相同。
可迁移时间管理模块320,用于分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间。
具体的,可迁移时间管理模块320可以为每个计算节点设置一个可用迁移时间,例如在每隔一定周期或者有典型事件(例如添加/删除计算节点到虚拟资源集群中、启动/关闭虚拟机等)触发资源调度时初始化每个计算节点的可用迁移时间。可选的,在初始化各计算节点的可用迁移时间时,可以先检测各计算节点当前是否正在进行虚拟机迁移,若当前计算节点i正在进行向计算节点j的虚拟机Vij的迁移,则可以将计算节点i的可用迁移时间初始化为MTi=Ni×T-MTVij,MTVij为迁移时间计算模块310根据待迁移虚拟机Vij的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽。
进而随着计算节点上发生的影响该可用迁移时间的典型事件(例如将原先运行在自身计算节点的虚拟机迁移至别的计算节点,或将原本运行在其他计算节点的虚拟机迁移至自身计算节点等)可以对该计算节点上的可用迁移时间进行更新,虚拟机迁移管理装置可以在决策需要从计算节点i迁移至计算节点j的虚拟机Vij后,分别获取源计算节点即计算节点i当前的可用迁移时间和目的计算节点即计算节点j当前的可用迁移时间。例如在迁移判断模块330确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,虚拟机迁移管理装置可以向所述源计算节点和目的计算节点分别下发虚拟机迁移指令,以使其开始进行所述待迁移虚拟机的虚拟机迁移,并由可迁移时间管理模块320将所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去所述迁移时间。而在其他可选实施例中,可迁移时间管理模块320也可以待所述待迁移虚拟机的迁移完成后,在所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去本次迁移的实际迁移时间。
迁移判断模块330,用于若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
即将迁移时间计算模块310计算得到的所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间分别与源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间进行比较,若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则迁移判断模块330确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点;若所述源计算节点当前的可用迁移时间小于所述迁移时间或所述目的计算节点当前的可用迁移时间均小于所述迁移时间,则迁移判断模块330确定所述待迁移虚拟机不可以从源计算节点迁移至目的计算节点。
在可选实施例中,在确定可以将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,迁移判断模块330可以向所述源计算节点和目的计算节点分别下发虚拟机迁移指令,以使其开始进行所述待迁移虚拟机的虚拟机迁移,与此同时迁移判断模块330可以通知可迁移时间管理模块320将所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去所述迁移时间。
可见,本实施例结合图3所描述的虚拟机迁移管理装置可以根据待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,可以对于计算节点的虚拟机并发迁移数量进行动态管理,实现了更为准确的对虚拟机迁移进行决策。
图4是本发明另一实施例中的虚拟机迁移管理装置的结构示意图,如图所示如图3所示,该虚拟机迁移管理装置400可以包括:至少一个处理器401,例如CPU,至少一个网络接口403,存储器404,至少一个通信总线402。其中,通信总线402用于实现这些组件之间的连接通信。网络接口403可选的可以包括标准的有线接口、无线接口(如WI-FI接口)。例如包括天线装置,用于与其他节点设备进行信令或数据的通信。存储器404可以是高速RAM存储器,也可以是非不稳定的存储器(non-volatile memory),例如至少一个磁盘存储器。存储器404可选的还可以是至少一个位于远离前述处理器401的存储装置。存储器404中存储一组程序代码,且处理器401用于调用存储器404中存储的程序代码,用于执行以下操作:
根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;
分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;
若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
进而在可选实施例中,所述根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。
进而在可选实施例中,可以采用先对虚拟机内存进行压缩再拷贝的方式进行虚拟机迁移,根据采用的压缩算法可以确定内存压缩比CVij,进而公式(1)可以调整为:
迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,n的确定方式与前文相同。
进而在可选实施例中,处理器401调用存储器404中存储的程序代码还可以执行以下步骤:
在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。从而使得下一次需要进行虚拟机迁移时可以根据更新后的可用迁移时间确定是否可以进行虚拟机迁移,从而实现了动态的对虚拟机迁移进行决策。对虚拟机迁移以实现对对应计算节点的可用迁移时间的准确管理,。
而在其他可选实施例中,虚拟机迁移管理装置也可以待所述待迁移虚拟机的迁移完成后,在所述源计算节点当前的可用迁移时间以及目的计算节点当前的可用迁移时间分别减去本次迁移的实际迁移时间,从而可以实现对计算节点的可用迁移时间更为准确的管理。
进而在可选实施例中,处理器401调用存储器404中存储的程序代码还可以执行以下步骤:
在每轮资源调度开始时初始化所有计算节点的可用迁移时间MTi=Ni×T,其中Ni为对应计算节点支持的并发迁移虚拟机数目,T为资源调度周期。
进而在可选实施例中,在初始化各计算节点的可用迁移时间时,可以检测各计算节点当前是否正在进行虚拟机迁移,若当前计算节点i正在进行向计算节点j的虚拟机Vij的迁移,则可以将计算节点i的可用迁移时间初始化为MTi=Ni×T-MTVij,MTVij为根据待迁移虚拟机Vij的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间。
可见,本实施例结合图4所描述的虚拟机迁移管理装置可以根据待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,可以对于计算节点的虚拟机并发迁移数量进行动态管理,实现了更为准确的对虚拟机迁移进行决策。
图5是本发明实施例提出的一种虚拟机迁移管理系统的结构示意图,如图所示本实施例中的虚拟机迁移管理系统至少可以包括至少两个承载虚拟机的计算节点设备510、计算节点设备520......计算机节点设备5n0以及虚拟机迁移管理装置500,其中:
所述虚拟机迁移管理装置500可以如前文任一实施例描述的虚拟机迁移管理装置,用于根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
所述计算节点设备用于在所述虚拟机迁移管理装置确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点时,负责将待迁移虚拟机进行迁移操作。
进而本实施例介绍的虚拟机迁移管理系统可以用以实现前文任一方法实施例中的全部或部分虚拟机迁移管理方法流程。
图6是本发明另一实施例中的一种虚拟机迁移管理系统,其特征在于,包括承载有至少一个待迁移虚拟机的源计算节点i620、目的计算节点j630,以及虚拟机迁移管理装置610,
所述虚拟机迁移管理装置610用于根据所述待迁移虚拟机的迁移参数计算所述待迁移虚拟机从所述源计算节点i620迁移至所述目的计算节点j630的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;分别获取所述源计算节点i620当前的可用迁移时间和所述目的计算节点j630当前的可用迁移时间;若所述源计算节点i620当前的可用迁移时间和所述目的计算节点j630当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点i620迁移至目的计算节点j630。
在可选实施例中,所述迁移时间可以通过以下两种中的任意一种实现方式计算获得:
待迁移虚拟机从源计算节点i620至目的计算节点j630的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,以及
待迁移虚拟机从源计算节点i620至目的计算节点j630的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
进而本实施例介绍的虚拟机迁移管理系统可以用以实现前文任一方法实施例中的全部或部分虚拟机迁移管理方法流程。
本发明实施例通过根据待迁移虚拟机的迁移参数动态地计算迁移时间,并将计算得到的迁移时间与源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间进行比较从而确定是否可以进行虚拟机迁移,可以对于计算节点的虚拟机并发迁移数量进行动态管理,实现了更为准确的对虚拟机迁移进行决策。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,所述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)或随机存储记忆体(Random Access Memory,RAM)等。
以上所揭露的仅为本发明较佳实施例而已,当然不能以此来限定本发明之权利范围,因此依本发明权利要求所作的等同变化,仍属本发明所涵盖的范围。

Claims (15)

1.一种虚拟机迁移管理方法,其特征在于,所述方法包括:
根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;
分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;
若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
2.如权利要求1所述的虚拟机迁移管理方法,其特征在于,所述根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。
3.如权利要求1所述的虚拟机迁移管理方法,其特征在于,所述根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
4.如权利要求1~3中任一项所述的虚拟机迁移管理方法,其特征在于,所述方法还包括:
在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。
5.如权利要求1~4中任一项所述的虚拟机迁移管理方法,其特征在于,所述方法还包括:
在每轮资源调度开始时初始化所有计算节点的可用迁移时间MTi=Ni×T,其中Ni为对应计算节点支持的并发迁移虚拟机数目,T为资源调度周期。
6.如权利要求5所述的虚拟机迁移管理方法,其特征在于,若在每轮资源调度开始时检测到计算节点正在进行虚拟机迁移,则初始化所述计算节点的可迁移时间MTi=Ni×T-MTVij,其中MTVij为该计算节点中正在进行迁移的虚拟机的迁移时间。
7.一种虚拟机迁移管理装置,其特征在于,包括:
迁移时间计算模块,用于根据待迁移虚拟机的迁移参数计算所述待迁移虚拟机从源计算节点迁移至目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;
可迁移时间管理模块,用于分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;
迁移判断模块,用于若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
8.如权利要求7所述的虚拟机迁移管理装置,其特征在于,所述可迁移时间管理模块还用于:
在开始将所述待迁移虚拟机从源计算节点迁移至目的计算节点后,在所述源计算节点当前的可用迁移时间中减去所述迁移时间,以及在所述目的计算节点当前的可用迁移时间中减去所述迁移时间。
9.如权利要求7所述的虚拟机迁移管理装置,其特征在于,所述迁移时间计算模块计算迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值。
10.如权利要求7所述的虚拟机迁移管理装置,其特征在于,所述迁移时间计算模块计算迁移时间包括:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
11.如权利要求7~10中任一项所述的虚拟机迁移管理装置,其特征在于,所述可迁移时间管理模块还用于:
在每轮资源调度开始时初始化所有计算节点的可用迁移时间MTi=Ni×T,其中Ni为对应计算节点支持的并发迁移虚拟机数目,T为资源调度周期。
12.如权利要求11所述的虚拟机迁移管理装置,其特征在于,所述可迁移时间管理模块还用于:
若在每轮资源调度开始时检测到计算节点正在进行虚拟机迁移,则初始化所述计算节点的可迁移时间MTi=Ni×T-MTVij,其中MTVij为该计算节点中正在进行迁移的虚拟机的迁移时间。
13.一种虚拟机迁移管理系统,其特征在于,包括至少两个承载虚拟机的计算节点设备和如权利要求7~12中任一项所述的虚拟机迁移管理装置。
14.一种虚拟机迁移管理系统,其特征在于,包括承载有至少一个待迁移虚拟机的源计算节点、目的计算节点,以及虚拟机迁移管理装置,
所述虚拟机迁移管理装置用于根据所述待迁移虚拟机的迁移参数计算所述待迁移虚拟机从所述源计算节点迁移至所述目的计算节点的迁移时间,其中所述迁移参数包括所述待迁移虚拟机的分配内存大小、内存改变速率以及迁移网络带宽;分别获取所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间;若所述源计算节点当前的可用迁移时间和所述目的计算节点当前的可用迁移时间均不小于所述迁移时间,则确定将所述待迁移虚拟机从源计算节点迁移至目的计算节点。
15.如权利要求14所述的虚拟机迁移管理系统,其特征在于,所述迁移时间可以通过以下两种中的任意一种实现方式计算获得:
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=MVij/BWVij,q=MCRVij×(MVij/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×q N-1小于预设内存脏页阈值的最小整数值,以及
待迁移虚拟机从源计算节点i至目的计算节点j的迁移时间MTVij=a0(1-qn)/(1-q),传输次数n=min{N0,N},其中a0=((MVij×CVij)/BWVij),q=MCRVij×((MVij×CVij)/BWVij)<1,MVij为所述待迁移虚拟机的分配内存大小,MCRVij为所述待迁移虚拟机的内存改变速率,BWVij为所述待迁移虚拟机分配得到的迁移网络带宽,N0为预设的最大传输次数,N为满足a0×qN-1小于预设内存脏页阈值的最小整数值,CVij为待迁移虚拟机的内存压缩比。
CN201310656235.1A 2013-12-06 2013-12-06 一种虚拟机迁移管理方法、装置及系统 Active CN103685256B (zh)

Priority Applications (6)

Application Number Priority Date Filing Date Title
CN201310656235.1A CN103685256B (zh) 2013-12-06 2013-12-06 一种虚拟机迁移管理方法、装置及系统
PCT/CN2014/083869 WO2015081717A1 (zh) 2013-12-06 2014-08-07 一种虚拟机迁移管理方法、装置及系统
KR1020167008845A KR101814560B1 (ko) 2013-12-06 2014-08-07 가상 머신 마이그레이션 관리 방법, 장치, 및 시스템
JP2016519928A JP6168576B2 (ja) 2013-12-06 2014-08-07 仮想マシンマイグレーション管理の方法、装置およびシステム
EP14795536.3A EP2894827B1 (en) 2013-12-06 2014-08-07 Method, apparatus, and system for managing migration of virtual machine
US14/557,994 US9720728B2 (en) 2013-12-06 2014-12-02 Migrating a VM when the available migration duration times of a source and destination node are greater than the VM's migration duration time

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201310656235.1A CN103685256B (zh) 2013-12-06 2013-12-06 一种虚拟机迁移管理方法、装置及系统

Publications (2)

Publication Number Publication Date
CN103685256A true CN103685256A (zh) 2014-03-26
CN103685256B CN103685256B (zh) 2017-08-04

Family

ID=50321571

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201310656235.1A Active CN103685256B (zh) 2013-12-06 2013-12-06 一种虚拟机迁移管理方法、装置及系统

Country Status (5)

Country Link
EP (1) EP2894827B1 (zh)
JP (1) JP6168576B2 (zh)
KR (1) KR101814560B1 (zh)
CN (1) CN103685256B (zh)
WO (1) WO2015081717A1 (zh)

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015081717A1 (zh) * 2013-12-06 2015-06-11 华为技术有限公司 一种虚拟机迁移管理方法、装置及系统
WO2016154786A1 (en) * 2015-03-27 2016-10-06 Intel Corporation Technologies for virtual machine migration
CN106227580A (zh) * 2016-07-18 2016-12-14 浪潮(北京)电子信息产业有限公司 一种虚拟机的动态迁移方法及系统
CN106874066A (zh) * 2017-01-20 2017-06-20 中兴通讯股份有限公司 一种虚拟机迁移方法及装置、电子设备
CN106970824A (zh) * 2017-03-07 2017-07-21 华中科技大学 一种基于带宽感知的虚拟机迁移压缩方法及系统
US9720728B2 (en) 2013-12-06 2017-08-01 Huawei Technologies Co., Ltd. Migrating a VM when the available migration duration times of a source and destination node are greater than the VM's migration duration time
CN107368349A (zh) * 2017-07-17 2017-11-21 郑州云海信息技术有限公司 一种资源管理方法及装置
CN107566319A (zh) * 2016-06-30 2018-01-09 中央大学 虚拟机器即时转移方法
CN109408195A (zh) * 2018-09-05 2019-03-01 华为技术有限公司 虚拟机热迁移方法及装置
CN113254161A (zh) * 2021-06-29 2021-08-13 飞腾信息技术有限公司 一种基于cpu的快速虚拟机热迁移方法
DE102015105884B4 (de) 2014-05-19 2023-01-05 Intel Corporation Rechenknoten und Verfahren zur Migration einer virtuellen Maschine, Rechenzentrummanager zur Migration virtueller Maschinen, Maschinenlesbares Speichermedium und Rechenvorrichtungen
CN117806776A (zh) * 2024-02-29 2024-04-02 山东海量信息技术研究院 一种数据迁移方法、装置及电子设备和存储介质

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109246229B (zh) * 2018-09-28 2021-08-27 网宿科技股份有限公司 一种分发资源获取请求的方法和装置
US11875169B2 (en) * 2020-07-21 2024-01-16 Google Llc Optimizing replication-based migration of virtual machines
KR102262645B1 (ko) 2020-12-31 2021-06-09 박용정 클라우드 컴퓨팅 환경에서의 리소스관리를 위한 모니터링 시스템 및 방법
KR102403625B1 (ko) * 2021-10-15 2022-05-30 오케스트로 주식회사 물리 서버 성능 저하를 고려하여 가상 머신 예측 관리를 구현한 가상 머신 배치 시스템 및 가상 머신 배치 방법

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8095929B1 (en) * 2007-04-16 2012-01-10 Vmware, Inc. Method and system for determining a cost-benefit metric for potential virtual machine migrations
CN102662763A (zh) * 2012-04-11 2012-09-12 华中科技大学 基于服务质量的虚拟机资源调度方法
CN102866915A (zh) * 2012-08-21 2013-01-09 华为技术有限公司 虚拟化集群整合方法、装置及虚拟化集群系统
CN103064733A (zh) * 2011-10-20 2013-04-24 电子科技大学 云计算虚拟机热迁移技术

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7484208B1 (en) * 2002-12-12 2009-01-27 Michael Nelson Virtual machine migration
JP4438807B2 (ja) * 2007-03-02 2010-03-24 日本電気株式会社 仮想マシンシステム、管理サーバ、仮想マシン移行方法及びプログラム
US9110702B2 (en) 2010-06-02 2015-08-18 Microsoft Technology Licensing, Llc Virtual machine migration techniques
JP5763961B2 (ja) * 2011-04-14 2015-08-12 キヤノン株式会社 通信装置、通信システム、通信装置の制御方法およびプログラム
EP2804100B1 (en) * 2012-01-10 2020-04-29 Fujitsu Limited Virtual machine management program, method and device
JP2013200615A (ja) * 2012-03-23 2013-10-03 Nec Corp 仮想マシン移動制御システム、仮想マシン移動方法およびプログラム
CN103685256B (zh) * 2013-12-06 2017-08-04 华为技术有限公司 一种虚拟机迁移管理方法、装置及系统

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8095929B1 (en) * 2007-04-16 2012-01-10 Vmware, Inc. Method and system for determining a cost-benefit metric for potential virtual machine migrations
CN103064733A (zh) * 2011-10-20 2013-04-24 电子科技大学 云计算虚拟机热迁移技术
CN102662763A (zh) * 2012-04-11 2012-09-12 华中科技大学 基于服务质量的虚拟机资源调度方法
CN102866915A (zh) * 2012-08-21 2013-01-09 华为技术有限公司 虚拟化集群整合方法、装置及虚拟化集群系统

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
HAIKUN LIU 等: "Performance and energy modeling for live migration of virtual machines", 《HIGH PERFORMANCE DISTRIBUTED COMPUTING,ACM》 *

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015081717A1 (zh) * 2013-12-06 2015-06-11 华为技术有限公司 一种虚拟机迁移管理方法、装置及系统
US9720728B2 (en) 2013-12-06 2017-08-01 Huawei Technologies Co., Ltd. Migrating a VM when the available migration duration times of a source and destination node are greater than the VM's migration duration time
DE102015105884B4 (de) 2014-05-19 2023-01-05 Intel Corporation Rechenknoten und Verfahren zur Migration einer virtuellen Maschine, Rechenzentrummanager zur Migration virtueller Maschinen, Maschinenlesbares Speichermedium und Rechenvorrichtungen
CN107430518A (zh) * 2015-03-27 2017-12-01 英特尔公司 用于虚拟机迁移的技术
WO2016154786A1 (en) * 2015-03-27 2016-10-06 Intel Corporation Technologies for virtual machine migration
CN107566319A (zh) * 2016-06-30 2018-01-09 中央大学 虚拟机器即时转移方法
CN106227580A (zh) * 2016-07-18 2016-12-14 浪潮(北京)电子信息产业有限公司 一种虚拟机的动态迁移方法及系统
CN106874066B (zh) * 2017-01-20 2021-01-26 中兴通讯股份有限公司 一种虚拟机迁移方法及装置、电子设备
CN106874066A (zh) * 2017-01-20 2017-06-20 中兴通讯股份有限公司 一种虚拟机迁移方法及装置、电子设备
CN106970824B (zh) * 2017-03-07 2019-12-17 华中科技大学 一种基于带宽感知的虚拟机迁移压缩方法及系统
CN106970824A (zh) * 2017-03-07 2017-07-21 华中科技大学 一种基于带宽感知的虚拟机迁移压缩方法及系统
CN107368349A (zh) * 2017-07-17 2017-11-21 郑州云海信息技术有限公司 一种资源管理方法及装置
CN107368349B (zh) * 2017-07-17 2020-09-08 郑州云海信息技术有限公司 一种资源管理方法及装置
CN109408195A (zh) * 2018-09-05 2019-03-01 华为技术有限公司 虚拟机热迁移方法及装置
CN113254161A (zh) * 2021-06-29 2021-08-13 飞腾信息技术有限公司 一种基于cpu的快速虚拟机热迁移方法
CN117806776A (zh) * 2024-02-29 2024-04-02 山东海量信息技术研究院 一种数据迁移方法、装置及电子设备和存储介质
CN117806776B (zh) * 2024-02-29 2024-05-10 山东海量信息技术研究院 一种数据迁移方法、装置及电子设备和存储介质

Also Published As

Publication number Publication date
EP2894827A1 (en) 2015-07-15
CN103685256B (zh) 2017-08-04
JP2016537705A (ja) 2016-12-01
WO2015081717A1 (zh) 2015-06-11
EP2894827A4 (en) 2015-09-02
KR101814560B1 (ko) 2018-01-04
EP2894827B1 (en) 2016-10-26
KR20160049006A (ko) 2016-05-04
JP6168576B2 (ja) 2017-07-26

Similar Documents

Publication Publication Date Title
CN103685256A (zh) 一种虚拟机迁移管理方法、装置及系统
US9720728B2 (en) Migrating a VM when the available migration duration times of a source and destination node are greater than the VM&#39;s migration duration time
US12093708B2 (en) Virtual machine scheduling method and apparatus
US11074092B2 (en) Virtual machine batch live migration
US9935865B2 (en) System and method for detecting and preventing service level agreement violation in a virtualized environment
CN106326002B (zh) 资源调度方法、装置及设备
US11194569B2 (en) Method, electronic device and medium for upgrading a hyper-converged infrastructure node
CN107301093B (zh) 一种管理资源的方法和装置
US11144330B2 (en) Algorithm program loading method and related apparatus
US9374314B2 (en) QoS aware balancing in data centers
CN103970587A (zh) 一种资源调度的方法、设备和系统
CN105700948A (zh) 一种用于在集群中调度计算任务的方法与设备
CN111143039B (zh) 一种虚拟机的调度方法、装置及计算机存储介质
US9471383B2 (en) Task allocation in a computing environment
CN103560915A (zh) 管理云计算系统中资源的方法和系统
CN108023834A (zh) 一种云资源自动分配方法及装置
CN109254843A (zh) 分配资源的方法和装置
CN115033340A (zh) 一种宿主机的选择方法及相关装置
CN115658311A (zh) 一种资源的调度方法、装置、设备和介质
CN114091589B (zh) 模型训练方法、装置、电子设备及介质
CN114780230A (zh) 一种内存分配方法、部署方法及相关装置
CN104866375B (zh) 一种迁移虚拟机的方法及装置
CN113703975A (zh) 模型分配方法、装置、电子设备及计算机可读存储介质
CN109992408A (zh) 一种资源分配方法、装置、电子设备和存储介质
CN117056023A (zh) 一种分布式系统存储资源调度方法及装置

Legal Events

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