CN113238832A - 虚拟处理器的调度方法、装置、设备及计算机存储介质 - Google Patents

虚拟处理器的调度方法、装置、设备及计算机存储介质 Download PDF

Info

Publication number
CN113238832A
CN113238832A CN202110553760.5A CN202110553760A CN113238832A CN 113238832 A CN113238832 A CN 113238832A CN 202110553760 A CN202110553760 A CN 202110553760A CN 113238832 A CN113238832 A CN 113238832A
Authority
CN
China
Prior art keywords
virtual
virtual machine
processor
virtual processor
switched
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.)
Pending
Application number
CN202110553760.5A
Other languages
English (en)
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.)
Yuanxin Information Technology Group Co ltd
Original Assignee
Yuanxin Information Technology Group 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 Yuanxin Information Technology Group Co ltd filed Critical Yuanxin Information Technology Group Co ltd
Priority to CN202110553760.5A priority Critical patent/CN113238832A/zh
Publication of CN113238832A publication Critical patent/CN113238832A/zh
Pending legal-status Critical Current

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/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)
  • Debugging And Monitoring (AREA)
  • Stored Programmes (AREA)

Abstract

本申请提供了一种虚拟处理器的调度方法、装置、电子设备及计算机存储介质,涉及计算机系统技术领域。该方法包括:确定一个管理虚拟机和至少一个执行虚拟机;管理虚拟机选择并执行虚拟处理器切换任务,以使待切换虚拟处理器陷入虚拟机监视器;将陷入虚拟机监视器的待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并调度该虚拟处理器切换任务,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,同时能够解决多域系统中虚拟处理器的调度问题。

Description

虚拟处理器的调度方法、装置、设备及计算机存储介质
技术领域
本申请涉及计算机系统技术领域,具体而言,本申请涉及一种虚拟处理器的调度方法、装置、设备及计算机存储介质。
背景技术
随着CPU性能的提升、实际应用中系统功耗、尺寸的限制、以及多核CPU和硬件虚拟化的技术支持,在一个硬件平台上利用虚拟化技术运行多个操作系统变为了可能和必须。
Hypervisor(虚拟机监视器)是一种运行在物理机和Guest OS(虚拟机)操作系统之间的中间软件层,目前的Hypervisor虚拟化,对CPU的调度分为两级。第一级是由Hypervisor对虚拟机分配的VCPU进行调度,第二级调度是由虚拟机对虚拟机自身任务的调度。虚拟化环境下的多域系统,Hypervisor运行在更接近物理硬件的一层,比虚拟机特权级别要高,而且控制着多域的启动以及分配给每个域的系统资源,因此Hypervisor需要有更高的安全等级。
而现有的多域系统CPU的两级调度方法,Hypervisor需要处理VCPU的调度,增大了Hypervisor代码量也扩大了Hypervisor的潜在攻击面,不利于Hypervisor的安全。
发明内容
本申请的目的旨在至少能解决上述的技术缺陷之一,特别是现有的多域系统CPU的两级调度方法,Hypervisor需要处理VCPU的调度,增大了代码量、扩大了系统潜在攻击面,不利于Hypervisor的安全的技术缺陷。
第一方面,提供了一种虚拟处理器的调度方法,应用于多域系统的虚拟机监视器,所述多域系统还包括所述虚拟处理器和至少两个虚拟机,所述调度方法包括:
从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;
确定各所述执行虚拟机与虚拟处理器之间的对应关系;
启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述虚拟处理器切换任务用于指示所述待切换虚拟处理器陷入所述虚拟机监视器;
将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
作为本申请一种可能的实施方式,在该实施方式中,所述确定各所述执行虚拟机与虚拟处理器间的对应关系,包括:
基于预设的配置文件,确定所述执行虚拟机与至少一个虚拟处理器间的对应关系。
作为本申请一种可能的实施方式,在该实施方式中,所述启动所述管理虚拟机,之后还包括:
指示所有虚拟处理器在所述管理虚拟机中运行;
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
保存所述待切换虚拟处理器在所述管理虚拟机中的运行内容。
作为本申请一种可能的实施方式,在该实施方式中,
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
恢复所述待切换虚拟处理器在目标执行虚拟机中的运行内容。
作为本申请一种可能的实施方式,在该实施方式中,
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
创建并启动运行定时器,所述运行定时器用于限制所述待切换虚拟处理器在目标执行虚拟机中的运行时长;
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之后,还包括:
当所述运行定时器超时后,停止所述待切换虚拟处理器在目标执行虚拟机中的运行;
将所述待切换虚拟处理器切换至所述管理虚拟机中运行。
第二方面,提供了一种虚拟处理器的调度方法,应用于多域系统的管理虚拟机,所述多域系统还包括所述虚拟处理器、虚拟机监视器和至少一个执行虚拟机,所述调度方法包括:
获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系;
创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行;
执行所述虚拟处理器切换任务。
第三方面,提供了一种虚拟处理器的调度装置,应用于多域系统的虚拟机监视器,所述多域系统还包括一个第一虚拟机和至少一个第二虚拟机,该装置包括:
虚拟机确认模块,用于从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;
关系对应模块,用于确定各所述执行虚拟机与虚拟处理器间的对应关系;
任务创建模块,用于启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述虚拟处理器切换任务用于指示所述待切换虚拟处理器陷入所述虚拟机监视器;
调度模块,用于将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
第四方面,提供了一种虚拟处理器的调度装置,应用于多域系统的管理虚拟机,所述多域系统还包括所述虚拟处理器、虚拟机监视器和至少一个执行虚拟机,所述调度方法包括:
关系获取模块,用于获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系;
任务创建模块,用于创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行;
任务执行模块,用于执行所述虚拟处理器切换任务。
第五方面,提供了一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现上述的虚拟处理器调度方法。
第四方面,提供了一种计算机存储介质,所述存储介质存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由所述处理器加载并执行以实现上述的虚拟处理器调度方法。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机中的调度器调度并执行虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对本申请实施例描述中所需要使用的附图作简单地介绍。
图1为本申请实施例提供的一种虚拟处理器的调度方法的流程示意图;
图2为本申请实施例提供的一种多域系统的框架示意图;
图3为本申请实施例提供的一种处理器切换时序图;
图4为本申请实施例提供的一种应用于管理虚拟机的虚拟处理器的调度方法的流程示意图;
图5为本申请实施例提供的一种应用于虚拟机监视器的调度装置的结构示意图;
图6为本申请实施例提供的一种应用于管理虚拟机的调度装置的结构示意图;
图7为本申请实施例提供的一种电子设备的结构示意图。
结合附图并参考以下具体实施方式,本申请各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。
具体实施方式
下面详细描述本申请的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本申请,而不能解释为对本申请的限制。
本技术领域技术人员可以理解,除非特意声明,这里使用的单数形式“一”、“一个”、“所述”和“该”也可包括复数形式。应该进一步理解的是,本申请的说明书中使用的措辞“包括”是指存在所述特征、整数、步骤、操作、元件和/或组件,但是并不排除存在或添加一个或多个其他特征、整数、步骤、操作、元件、组件和/或它们的组。应该理解,当我们称元件被“连接”或“耦接”到另一元件时,它可以直接连接或耦接到其他元件,或者也可以存在中间元件。此外,这里使用的“连接”或“耦接”可以包括无线连接或无线耦接。这里使用的措辞“和/或”包括一个或更多个相关联的列出项的全部或任一单元和全部组合。
为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。
本申请提供的虚拟处理器的调度方法、装置、电子设备和计算机存储介质,旨在解决现有技术的如上技术问题。
下面以具体地实施例对本申请的技术方案以及本申请的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本申请的实施例进行描述。
本申请实施例中提供了一种虚拟处理器的调度方法,该方法应用于多域系统的虚拟机监视器中,其中,该多域系统中还包括虚拟处理器和至少两个虚拟机,如图1所示,该方法包括:
步骤S101,从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机。
在本申请实施例中,提供的虚拟处理器的调度方法应用于虚拟环境下的多域系统,该多域系统中包括虚拟机监视器、多个虚拟机以及多个虚拟处理器,其中,多个虚拟处理器由虚拟机监视器对物理处理器虚化得到,虚拟机监视器在对虚拟机进行管理时,先将虚拟机中的一个确定为管理虚拟机,将除管理虚拟机之外的其它虚拟机确定为执行虚拟机,并将所有的虚拟处理器都分配至管理虚拟机,由管理虚拟机对虚拟处理器进行调度。
步骤S102,确定各所述执行虚拟机与虚拟处理器间的对应关系。
在本申请实施例中,在多域系统初始化之后,根据预设置的配置文件,确定各执行虚拟机与虚拟处理器之间的对应关系。各执行虚拟机与虚拟处理器之间的对应关系是指哪个或哪些虚拟处理器可以切换至哪个执行虚拟机中进行运行,为方便说明,以一个具体实施例为例,管理虚拟机为VM0,执行虚拟机包括VM1、VM2,虚拟处理器包括VCPU0、VCPU1、VCPU2以及VCPU3,系统启动时,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机VM0中运行,此时,虚拟机监视器需要确认各执行虚拟机与各虚拟处理器之间的对应关系,如确定VCPU0可以切换至VM1中运行,VCPU1、VCPU、VCPU3以切换至VM2中运行。当然,执行虚拟机的数量和虚拟处理器的数量可以更多,执行虚拟机与虚拟处理器的对应关系也可以不同,这些可以根据实际情况进行变更。
步骤S103,启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述虚拟处理器切换任务用于指示所述待切换虚拟处理器陷入所述虚拟机监视器。
在本申请实施例中,当多域系统初始化完成之后,启动管理虚拟机,该管理虚拟机中运行有成熟的操作系统,如Windows系统、Linux系统等,当管理虚拟机启动后,该管理虚拟机中的操作系统陷入虚拟机监视器中,获取每个执行虚拟机与虚拟处理器之间的对应关系,并基于该对应关系为每个执行虚拟机的虚拟处理器创建虚拟处理器切换任务,该虚拟处理器切换任务中至少包括有待切换虚拟处理器的身份标识,为方便说明,以前述实施例为例,管理虚拟机为VM0,执行虚拟机包括VM1、VM2,虚拟处理器包括VCPU0、VCPU1、VCPU2、VCPU3,系统启动时,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机VM0中运行,此时,虚拟机监视器需要确认各执行虚拟机与各虚拟处理器之间的对应关系,如确定VCPU0可以切换至VM1中运行,VCPU1、VCPU2、VCPU3可以切换至VM2中运行,则在为每个执行虚拟机的虚拟处理器创建虚拟处理器切换任务时,作为本申请一种可能的实施方式,该虚拟处理器切换任务可以是daemon(守护进程任务)任务,如可以创建的任务为VM1_VCPU0_daemon、VM1_VCPU1_daemon、VM2_VCPU2_daemon、VM2_VCPU3_daemon,其中,VM1、VM2分别表示虚拟机的身份信息,VCPU0、VCPU1、VCPU2、VCPU3分别表示虚拟处理器的身份标识。
在本申请实施例中,当系统初始化完成之后,管理虚拟机会在任务队列中循环选择新的任务执行,当选择到某个虚拟处理器的虚拟处理器切换任务时,如执行到的虚拟处理器切换任务为VM1_VCPU0_daemon,则基于该任务,VCPUO会陷入虚拟机监视器。
步骤S104,将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
在本申请实施例中,基于上述实施例,虚拟机监视器会将陷入的待切换虚拟处理器切换至对应的执行虚拟机中运行,例如,虚拟处理器切换任务为VM1_VCPU0_daemon,则待切换虚拟处理器为VCPU0,虚拟机监视器会将VCPU0切换至执行虚拟机VM1中运行。
在本申请实施例中,如图2所示,为本申请实施例提供的一种多域系统的框架示意图,其中,管理虚拟机VM0和执行虚拟机中都存在Task任务,且管理虚拟机中还存在各执行虚拟机中各虚拟处理器的虚拟处理器切换任务。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机中的调度器调度并执行虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
作为本申请一种可能的实施方式,在该实施方式中,所述确定各所述执行虚拟机与虚拟处理器间的对应关系,包括:
基于预设的配置文件,确定所述执行虚拟机与至少一个虚拟处理器间的对应关系。
在本申请实施例中,在确定各执行虚拟机与虚拟处理器之间的对应关系时,可以基于预设置的配置文件确定,其中,该预设置的配置文件可以是工作人员基于执行虚拟机中运行程序的复杂程度确定的,其中,各所述执行虚拟机运行程序的复杂程度可以是根据各执行虚拟机中运行程序的种类确定的,也可以是根据各执行虚拟机运行程序的代码数量确定的,当然,这些都是工作人员根据先验知识确定的。
在本申请实施例中,为方便说明,以一个具体实施例为例,基于各执行虚拟机中运行程序的复杂程度,确定各执行虚拟机对应的虚拟处理器,例如,管理虚拟机为VM0,执行虚拟机包括VM1、VM2,虚拟处理器包括VCPU0、VCPU1、VCPU2、VCPU3,系统启动时,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机VM0,其中,执行虚拟机VM1中运行的是完整的操作系统,如linux系统,属于较为复杂的程序,需要分配两个虚拟处理器,可以将VCPU0、VCPU1与执行虚拟机VM1建立对应关系,执行虚拟机VM2中运行的是简单的裸机程序,只需要一个虚拟处理器,则可以将VCPU2与执行虚拟机VM2建立对应关系。当然,执行虚拟机的数量可以更多,虚拟处理器的数量也可以更多,执行虚拟机与虚拟处理器之间的对应关系可以根据实际情况进行配置。
本申请实施例通过基于执行虚拟机运行的程序的复杂程度,确定各执行虚拟机与至少一个虚拟处理器的对应关系,保证虚拟处理器的资源利用最大化。
作为本申请一种可能的实施方式,在该实施方式中,所述启动所述管理虚拟机,之后还包括:
指示所有虚拟处理器在所述管理虚拟机中运行;
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
保存所述待切换虚拟处理器在所述管理虚拟机中的运行内容。
在本身实施例中,虚拟机监视器在启动管理虚拟机之后,将所有的虚拟处理器都切换至管理虚拟机中运行,方便管理虚拟机选择任务进行执行,此时,所有的虚拟处理器都运行在管理虚拟机中,当管理虚拟机选择到一个虚拟处理器的虚拟处理器切换任务时,对应的虚拟处理器会陷入虚拟机监视器,此时虚拟监视器会保存该虚拟处理器在管理虚拟机中运行内容的上下文。为方便说明,以一个具体实施例为例,管理虚拟机为VM0,执行虚拟机包括VM1、VM2,虚拟处理器包括VCPU0、VCPU1、VCPU2、VCPU3,系统启动时,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机VM0,此时,虚拟机监视器需要确认各执行虚拟机与各虚拟处理器之间的对应关系,如确定VCPU0可以切换至VM1中运行,VCPU1、VCPU2可以切换至VM2中运行,则在为每个执行虚拟机的虚拟处理器创建虚拟处理器切换任务时,可以创建的任务为VM1_VCPU0_daemon、VM1_VCPU1_daemon、VM2_VCPU2_daemon,其中,VM1、VM1分别表示虚拟机的身份信息,VCPU0、VCPU1、VCPU2分别表示虚拟处理器的身份标识,管理虚拟机启动后,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机中运行,当管理虚拟机选择到VM1_VCPU0_daemon这一虚拟处理器切换任务时,将该任务切换至VCPU0中运行,此时VCPU0会陷入虚拟机监视器,虚拟机监视器开始保存VCPU0在管理虚拟机VM0中的运行内容的上下文。
本申请实施例通过保存待切换虚拟处理器在管理虚拟机中运行内容的上下文,保证待切换虚拟处理器在执行虚拟机中运行完成后能够返回管理虚拟机继续完成任务。
作为本申请一种可能的实施方式,在该实施方式中,所述执行所述虚拟处理器切换任务,将所述待切换虚拟处理器切换至目标执行虚拟机中运行之前,还包括:
恢复所述待切换虚拟处理器在目标执行虚拟机中的运行内容。
在本申请实施例中,在将待切换虚拟机处理器分至目标执行虚拟机中之前,需要先恢复该待切换虚拟处理器在该目标执行虚拟机中的运行内容,便于该待切换虚拟处理器被切换至该目标执行虚拟机中之后,能够继续执行该进程。
本申请实施例通过恢复该待切换虚拟处理器在该目标执行虚拟机中的运行内容,便于待切换虚拟处理器在被分配到该目标执行虚拟机在中之后,能够继续执行任务。
作为本申请一种可能的实施方式,在该实施方式中,所述执行所述虚拟处理器切换任务,将所述待切换虚拟处理器切换至目标执行虚拟机中运行之前,还包括:
创建并启动运行定时器,所述运行定时器用于限制所述待切换虚拟处理器在目标执行虚拟机中的运行时长;
所述执行所述虚拟处理器切换任务,将所述待切换虚拟处理器切换至目标执行虚拟机中运行之后,还包括:
当所述运行定时器超时后,停止所述待切换虚拟处理器在目标执行虚拟机中的运行;
将所述待切换虚拟处理器切换至所述管理虚拟机中运行。
在本申请实施例中,在对虚拟处理器进行调度时,需要创建运行定时器,运行定时器用于限制所述待切换虚拟处理器在目标执行虚拟机中的运行时长,当所述运行定时器超时后,停止所述待切换虚拟处理器在目标执行虚拟机中的运行;将所述待切换虚拟处理器切换至所述管理虚拟机中运行。
对于本申请实施例,为方便说明,以一个具体实施例为例,管理虚拟机为VM0、执行虚拟机为VM1,虚拟处理器为VCPU0,如图3所示,为本申请实施例提供的一种虚拟处理器的调度时序图,管理虚拟机选择新的任务执行,当选择到VCPU0的虚拟处理器切换任务时,启动执行定时器,VCPU0陷入虚拟机监视器,虚拟机监视器执行VCPU0在VM0和VM1之间的切换,当定时器时间超时,中断发生,并返回至VM0,VM0重新选择其它任务执行。
本申请实施例通过设置执行定时器,保证待切换虚拟处理器在目标执行虚拟机中的运行时间,保证工作效率。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
本申请实施例提供了一种虚拟处理器的调度方法,应用于多域系统的管理虚拟机,所述多域系统还包括所述虚拟处理器、虚拟机监视器和至少一个执行虚拟机,如图4所示,所述调度方法包括:
步骤S401,获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系。
在本申请实施例中,该虚拟处理器的调度方法应用于管理虚拟机,管理虚拟机在启动后,陷入虚拟机监视器,获取虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系,为方便说明,以前述实施例为例,管理虚拟机为VM0,执行虚拟机包括VM1、VM2,虚拟处理器包括VCPU0、VCPU1、VCPU2、VCPU3,系统启动时,VCPU0、VCPU1、VCPU2、VCPU3都在管理虚拟机VM0,此时,虚拟机监视器需要确认各执行虚拟机与各虚拟处理器之间的对应关系,如确定VCPU0可以切换至VM1中运行,VCPU1、VCPU2、VCPU3可以切换至VM2中运行。
步骤S402,创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行。
在本申请实施例中,在获取到各执行虚拟机与各虚拟处理器之间的对应关系之后,针对每个执行虚拟机中的每个虚拟处理器创建虚拟处理器切换任务,如确定VCPU0可以切换至VM1中运行,VCPU1、VCPU2可以切换至VM2中运行,则在为每个执行虚拟机的虚拟处理器创建虚拟处理器切换任务时,可以创建的任务为VM1_VCPU0_daemon、VM1_VCPU1_daemon、VM2_VCPU2_daemon、VM2_VCPU3_daemon,其中,VM1、VM1分别表示虚拟机的身份信息,VCPU0、VCPU1、VCPU2、VCPU3分别表示虚拟处理器的身份标识,并将这些虚拟处理器切换任务发送至任务队列。
步骤S403,执行所述虚拟处理器切换任务。
在本申请实施例中,管理虚拟机会循环选择任务队列中的任务执行,当选择到虚拟处理器切换任务时,执行该虚拟处理器切换任务,其中,执行过程前述实施例中已经说明,此处不再赘述。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
本申请实施例提供了一种虚拟处理器的调度装置,如图5所示,该虚拟处理器的调度装置50可以包括:虚拟机确认模块501、关系对应模块502、任务创建模块503、以及调度模块504,其中,
虚拟机确认模块501,用于从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;
关系对应模块502,用于确定各所述执行虚拟机与虚拟处理器间的对应关系;
任务创建模块503,用于启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述管理虚拟机将所述虚拟处理器切换任务切换至对应的待切换虚拟处理器,以使所述待切换虚拟处理器陷入所述虚拟机监视器;
调度模块504,用于将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
作为本申请一种可能的实施方式,关系对应模块502在确定各所述执行虚拟机与虚拟处理器间的对应关系时,可以用于:
基于预设的配置文件,确定所述执行虚拟机与至少一个虚拟处理器间的对应关系。
作为本申请一种可能的实施方式,任务创建模块503在启动所述管理虚拟机,之后还可以用于:
指示所有虚拟处理器在所述管理虚拟机中运行;
调度模块504在将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还可以用于:
保存所述待切换虚拟处理器在所述管理虚拟机中的运行内容。
作为本申请一种可能的实施方式,在该实施方式中,调度模块504在将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还可以用于:
恢复所述待切换虚拟处理器在目标执行虚拟机中的运行内容。
作为本申请一种可能的实施方式,在该实施方式中,调度模块504在将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还可以用于:
创建并启动运行定时器,所述运行定时器用于限制所述待切换虚拟处理器在目标执行虚拟机中的运行时长;
调度模块504在将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之后,还可以用于:
当所述运行定时器超时后,停止所述待切换虚拟处理器在目标执行虚拟机中的运行;
将所述待切换虚拟处理器切换至所述管理虚拟机中运行。
本申请实施例的虚拟处理器的调度装置可执行本申请前述实施例所示的虚拟处理器的调度方法,其实现原理相类似,此处不再赘述。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
本申请实施例提供了一种虚拟处理器的调度装置,如图6所示,该虚拟处理器的调度装置60可以包括:关系获取模块601、任务创建模块602、以及任务执行模块603,其中,
关系获取模块601,用于获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系;
任务创建模块602,用于创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行;
任务执行模块603,用于执行所述虚拟处理器切换任务。
本申请实施例的虚拟处理器的调度装置可执行本申请前述实施例所示的虚拟处理器的调度方法,其实现原理相类似,此处不再赘述。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
本申请实施例中提供了一种电子设备,该电子设备包括:存储器和处理器;至少一个程序,存储于存储器中,用于被处理器执行时,从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;确定各所述执行虚拟机与虚拟处理器间的对应关系;启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述管理虚拟机将所述虚拟处理器切换任务切换至对应的待切换虚拟处理器,以使所述待切换虚拟处理器陷入所述虚拟机监视器;将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
在一个可选实施例中提供了一种电子设备,如图7所示,图7所示的电子设备4000包括:处理器4001和存储器4003。其中,处理器4001和存储器4003相连,如通过总线4002相连。可选地,电子设备4000还可以包括收发器4004。需要说明的是,实际应用中收发器4004不限于一个,该电子设备4000的结构并不构成对本申请实施例的限定。
处理器4001可以是CPU(Central Processing Unit,中央处理器),通用处理器,DSP(Digital Signal Processor,数据信号处理器),ASIC(Application SpecificIntegrated Circuit,专用集成电路),FPGA(Field Programmable Gate Array,现场可编程门阵列)或者其他可编程逻辑器件、晶体管逻辑器件、硬件部件或者其任意组合。其可以实现或执行结合本申请公开内容所描述的各种示例性的逻辑方框,模块和电路。处理器4001也可以是实现计算功能的组合,例如包含一个或多个微处理器组合,DSP和微处理器的组合等。
总线4002可包括一通路,在上述组件之间传送信息。总线4002可以是PCI(Peripheral Component Interconnect,外设部件互连标准)总线或EISA(ExtendedIndustry Standard Architecture,扩展工业标准结构)总线等。总线4002可以分为地址总线、数据总线、控制总线等。为便于表示,图7中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
存储器4003可以是ROM(Read Only Memory,只读存储器)或可存储静态信息和指令的其他类型的静态存储设备,RAM(Random Access Memory,随机存取存储器)或者可存储信息和指令的其他类型的动态存储设备,也可以是EEPROM(Electrically ErasableProgrammable Read Only Memory,电可擦可编程只读存储器)、CD-ROM(Compact DiscRead Only Memory,只读光盘)或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。
存储器4003用于存储执行本申请方案的应用程序代码,并由处理器4001来控制执行。处理器4001用于执行存储器4003中存储的应用程序代码,以实现前述方法实施例所示的内容。
其中,电子设备包括但不限于:电脑、服务器、云服务器、平板电脑等。
本申请实施例提供了一种计算机存储介质,该计算机存储介质上存储有计算机程序,当其在计算机上运行时,使得计算机可以执行前述方法实施例中相应内容。与现有技术相比,本申请实施例通过将虚拟机分为管理虚拟机和执行虚拟机,并确定各执行虚拟机与各虚拟处理器之间的关系,通过管理虚拟机创建各执行虚拟机中各虚拟处理器的虚拟处理器切换任务,并由管理虚拟机读取虚拟处理器切换任务,以使该虚拟处理器切换任务对应的虚拟处理器陷入虚拟机监视器,虚拟机监视器将该虚拟处理器切换至对应的执行虚拟机进行运行,虚拟机监视器只需要执行虚拟处理器的切换,大大简化了虚拟机监视器的程序代码量,增强了虚拟机监视器的安全性,且同时能够解决多域系统中虚拟处理器的调度问题。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
以上所述仅是本申请的部分实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本申请原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本申请的保护范围。

Claims (10)

1.一种虚拟处理器的调度方法,应用于多域系统的虚拟机监视器,其特征在于,所述多域系统还包括所述虚拟处理器和至少两个虚拟机,所述调度方法包括:
从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;
确定各所述执行虚拟机与虚拟处理器之间的对应关系;
启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述虚拟处理器切换任务用于指示所述待切换虚拟处理器陷入所述虚拟机监视器;
将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
2.根据权利要求1所述的虚拟处理器的调度方法,其特征在于,所述确定各所述执行虚拟机与虚拟处理器之间的对应关系,包括:
基于预设的配置文件,确定所述执行虚拟机与至少一个虚拟处理器间的对应关系。
3.根据权利要求1所述的虚拟处理器的调度方法,其特征在于,所述启动所述管理虚拟机,之后还包括:
指示所有虚拟处理器在所述管理虚拟机中运行;
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
保存所述待切换虚拟处理器在所述管理虚拟机中的运行内容。
4.根据权利要求1所述的虚拟处理器的调度方法,其特征在于,所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
恢复所述待切换虚拟处理器在目标执行虚拟机中的运行内容。
5.根据权利要求1所述的虚拟处理器的调度方法,其特征在于,所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之前,还包括:
创建并启动运行定时器,所述运行定时器用于限制所述待切换虚拟处理器在目标执行虚拟机中的运行时长;
所述将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行之后,还包括:
当所述运行定时器超时后,停止所述待切换虚拟处理器在目标执行虚拟机中的运行;
将所述待切换虚拟处理器切换至所述管理虚拟机中运行。
6.一种虚拟处理器的调度方法,应用于多域系统的管理虚拟机,其特征在于,所述多域系统还包括所述虚拟处理器、虚拟机监视器和至少一个执行虚拟机,所述调度方法包括:
获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系;
创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行;
执行所述虚拟处理器切换任务。
7.一种虚拟处理器调度装置,应用于多域系统的虚拟机监视器,所述多域系统还包括一个第一虚拟机和至少一个第二虚拟机,其特征在于,包括:
虚拟机确认模块,用于从所述至少两个虚拟机中确定一个管理虚拟机,将除所述第一虚拟机之外的其他虚拟机作为执行虚拟机;
关系对应模块,用于确定各所述执行虚拟机与虚拟处理器间的对应关系;
任务确定模块,用于启动所述管理虚拟机,以使所述管理虚拟机创建并执行虚拟处理器切换任务;其中,所述虚拟处理器切换任务包括待切换虚拟处理器的身份标识,所述虚拟处理器切换任务用于指示所述待切换虚拟处理器陷入所述虚拟机监视器;
调度模块,用于将陷入所述虚拟机监视器的所述待切换虚拟处理器切换至存在对应关系的目标执行虚拟机中运行。
8.一种虚拟处理器的调度装置,应用于多域系统的管理虚拟机,其特征在于,所述多域系统还包括所述虚拟处理器、虚拟机监视器和至少一个执行虚拟机,所述装置包括:
关系获取模块,用于获取所述虚拟机监视器为各所述执行虚拟机分配的虚拟处理器信息的对应关系;
任务创建模块,用于创建虚拟处理器切换任务,所述虚拟处理器切换任务用于指示所述虚拟监视器将待切换虚拟处理器切换至所述待切换虚拟处理器对应的目标执行虚拟机中运行;
任务执行模块,用于执行所述虚拟处理器切换任务。
9.一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现权利要求1~7中任一项所述的虚拟处理器调度方法。
10.一种计算机存储介质,其特征在于,所述存储介质存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由所述处理器加载并执行以实现如权利要求1~7中任一项所述的虚拟处理器调度方法。
CN202110553760.5A 2021-05-20 2021-05-20 虚拟处理器的调度方法、装置、设备及计算机存储介质 Pending CN113238832A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110553760.5A CN113238832A (zh) 2021-05-20 2021-05-20 虚拟处理器的调度方法、装置、设备及计算机存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110553760.5A CN113238832A (zh) 2021-05-20 2021-05-20 虚拟处理器的调度方法、装置、设备及计算机存储介质

Publications (1)

Publication Number Publication Date
CN113238832A true CN113238832A (zh) 2021-08-10

Family

ID=77138069

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110553760.5A Pending CN113238832A (zh) 2021-05-20 2021-05-20 虚拟处理器的调度方法、装置、设备及计算机存储介质

Country Status (1)

Country Link
CN (1) CN113238832A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114020330A (zh) * 2021-11-04 2022-02-08 苏州睿芯集成电路科技有限公司 Risc-v处理器验证中模式切换的方法、电子设备以及存储介质
CN115576645A (zh) * 2022-09-29 2023-01-06 中汽创智科技有限公司 一种虚拟处理器调度方法、装置、存储介质及电子设备

Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020178262A1 (en) * 2001-05-22 2002-11-28 David Bonnell System and method for dynamic load balancing
JP2009080563A (ja) * 2007-09-25 2009-04-16 Nec Corp 仮想マシンモニタをモニタするコンピュータとその方法、および仮想マシンモニタモニタプログラム
US20100057908A1 (en) * 2008-08-27 2010-03-04 Cisco Technology, Inc. Centralized control plane appliance for virtual infrastructure
CN101727351A (zh) * 2009-12-14 2010-06-09 北京航空航天大学 面向多核平台的虚拟机监控器非对称调度器及其调度方法
JP2011198027A (ja) * 2010-03-19 2011-10-06 Fujitsu Ltd 仮想マシンシステムおよび仮想マシン管理方法
CN102253857A (zh) * 2011-06-24 2011-11-23 华中科技大学 一种多核环境下的Xen虚拟机调度控制方法
US8539499B1 (en) * 2008-02-18 2013-09-17 Parallels IP Holdings GmbH Symmetric multiprocessing with virtual CPU and VSMP technology
US20150242229A1 (en) * 2014-02-27 2015-08-27 Red Hat Israel, Ltd. Idle processor management by guest in virtualized systems
US20170132030A1 (en) * 2014-03-27 2017-05-11 Nec Corporation Virtual machine system, control method thereof, and control program recording medium thereof
CN108255572A (zh) * 2016-12-29 2018-07-06 华为技术有限公司 一种vcpu切换方法和物理主机
CN110515701A (zh) * 2019-08-28 2019-11-29 杭州数梦工场科技有限公司 一种虚拟机的热迁移方法及装置
US20200174816A1 (en) * 2018-11-30 2020-06-04 Nutanix, Inc. Intelligent assignment of virtual machines to compute only or hyper converged nodes
CN111459623A (zh) * 2019-01-18 2020-07-28 华为技术有限公司 应用程序恢复运行的方法、装置及计算机
CN112579257A (zh) * 2020-12-14 2021-03-30 深信服科技股份有限公司 一种虚拟中央处理器核心的调度方法、装置及相关设备

Patent Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020178262A1 (en) * 2001-05-22 2002-11-28 David Bonnell System and method for dynamic load balancing
JP2009080563A (ja) * 2007-09-25 2009-04-16 Nec Corp 仮想マシンモニタをモニタするコンピュータとその方法、および仮想マシンモニタモニタプログラム
US8539499B1 (en) * 2008-02-18 2013-09-17 Parallels IP Holdings GmbH Symmetric multiprocessing with virtual CPU and VSMP technology
US20100057908A1 (en) * 2008-08-27 2010-03-04 Cisco Technology, Inc. Centralized control plane appliance for virtual infrastructure
CN101727351A (zh) * 2009-12-14 2010-06-09 北京航空航天大学 面向多核平台的虚拟机监控器非对称调度器及其调度方法
JP2011198027A (ja) * 2010-03-19 2011-10-06 Fujitsu Ltd 仮想マシンシステムおよび仮想マシン管理方法
CN102253857A (zh) * 2011-06-24 2011-11-23 华中科技大学 一种多核环境下的Xen虚拟机调度控制方法
US20150242229A1 (en) * 2014-02-27 2015-08-27 Red Hat Israel, Ltd. Idle processor management by guest in virtualized systems
US20170132030A1 (en) * 2014-03-27 2017-05-11 Nec Corporation Virtual machine system, control method thereof, and control program recording medium thereof
CN108255572A (zh) * 2016-12-29 2018-07-06 华为技术有限公司 一种vcpu切换方法和物理主机
US20200174816A1 (en) * 2018-11-30 2020-06-04 Nutanix, Inc. Intelligent assignment of virtual machines to compute only or hyper converged nodes
CN111459623A (zh) * 2019-01-18 2020-07-28 华为技术有限公司 应用程序恢复运行的方法、装置及计算机
CN110515701A (zh) * 2019-08-28 2019-11-29 杭州数梦工场科技有限公司 一种虚拟机的热迁移方法及装置
CN112579257A (zh) * 2020-12-14 2021-03-30 深信服科技股份有限公司 一种虚拟中央处理器核心的调度方法、装置及相关设备

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
LUDMILA CHERKASOVA ET AL.: "Comparison of the three CPU schedulers in Xen", ACM SIGMETRICS PERFORMANCE EVALUATION REVIEW, vol. 35, no. 02, pages 42 - 51, XP058313715, DOI: 10.1145/1330555.1330556 *
奚智等: "基于微内核的嵌入式虚拟化技术", 单片机与嵌入式系统应用, vol. 21, no. 02, pages 20 - 23 *
张颜: "基于XEN虚拟机的处理器调度算法研究", 中国优秀硕士学位论文全文数据库 (信息科技辑), no. 02, pages 137 - 10 *
时光;郭玉东;王晓睿;李勇;: "Xen中VCPU调度算法分析", 计算机工程与设计, vol. 31, no. 18, pages 4116 - 4119 *
胡晓静;王春光;谭郁松;: "面向众核的空分系统结构研究", 机械科学与技术, no. 06, pages 868 - 872 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114020330A (zh) * 2021-11-04 2022-02-08 苏州睿芯集成电路科技有限公司 Risc-v处理器验证中模式切换的方法、电子设备以及存储介质
CN114020330B (zh) * 2021-11-04 2023-11-03 苏州睿芯集成电路科技有限公司 Risc-v处理器验证中模式切换的方法、电子设备以及存储介质
CN115576645A (zh) * 2022-09-29 2023-01-06 中汽创智科技有限公司 一种虚拟处理器调度方法、装置、存储介质及电子设备
CN115576645B (zh) * 2022-09-29 2024-03-08 中汽创智科技有限公司 一种虚拟处理器调度方法、装置、存储介质及电子设备

Similar Documents

Publication Publication Date Title
KR101668399B1 (ko) 프로세서 코어들의 하이퍼바이저 격리
CN107479943B (zh) 基于工业互联网操作系统的多操作系统运行方法及装置
JP6381956B2 (ja) 動的仮想マシンサイジング
KR101907564B1 (ko) 운영 체제 분리형 이종 컴퓨팅 기법
US10871982B2 (en) Virtual processor scheduling via memory monitoring
US11157302B2 (en) Idle processor management in virtualized systems via paravirtualization
US11579918B2 (en) Optimizing host CPU usage based on virtual machine guest OS power and performance management
WO2013165447A1 (en) Hybrid operating system
KR20060108711A (ko) 액티비티 정보를 이용한 가상 머신 관리
US20160196157A1 (en) Information processing system, management device, and method of controlling information processing system
CN115269057B (zh) 基于设备树的隔离系统生成配置文件的方法
CN110447012B (zh) 协作虚拟处理器调度
CN107003713B (zh) 用于电力管理的逻辑分区的事件驱动的方法和系统
CN111324432B (zh) 处理器调度方法、装置、服务器及存储介质
CN113238832A (zh) 虚拟处理器的调度方法、装置、设备及计算机存储介质
WO2018040845A1 (zh) 一种计算资源调度方法及装置
US20190377612A1 (en) VCPU Thread Scheduling Method and Apparatus
US8464258B2 (en) Virtual computer and CPU allocation method
US10963250B2 (en) Selectively suppressing time intensive instructions based on a control value
US11720388B2 (en) Management of dynamic sharing of central processing units
US10810032B2 (en) System and method for dynamic guest-controlled halt polling using a CPU governor
US11182184B2 (en) Implementing high-performance virtual machines for bare metal simulation
CN108009007B (zh) 轻量级线程的调度方法及协同管理器、vCPU调度器
CN114691296A (zh) 中断处理方法、装置、介质及设备
WO2019125254A1 (en) Management of dynamic sharing of central processing units

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