一种服务器、资源管理方法及虚拟机管理器的制造方法
【技术领域】
[0001]本申请涉及虚拟计算技术领域,尤其涉及一种服务器、资源管理方法及虚拟机管理器。
【背景技术】
[0002]虚拟化技术通过虚拟机管理器在物理硬件上生成多个可以运行独立操作系统的虚拟机实例,以提高每台服务器的平均资源利用率。因此,各种虚拟化技术应运而生。
[0003]然而,现有技术中的一个虚拟机管理器通常管理一台服务器上的所有处理处理器。因此导致虚拟机管理器内的实现复杂度大,而且性能损耗高。
【发明内容】
[0004]本申请实施例提供一种服务器、资源管理方法及虚拟机管理器,用以解决现有技术中的虚拟机管理器的实现复杂度和性能损耗较高的技术问题。
[0005]本申请第一方面提供了一种服务器,包括:
[0006]N类物理处理器核心;N为大于I的正整数;
[0007]控制器,用于根据所述N类物理处理器核心的种类部署M个虚拟机管理器,每个所述虚拟机管理器用于管理一个物理处理器核心区,每个所述物理处理器核心区属于所述N类物理处理器中核心的一类;其中,M为大于等于N的正整数。
[0008]结合第一方面,在第一方面的第一种可能的实现方式中,所述控制器具体用于:根据所述N类物理处理器核心的种类部署N个虚拟机管理器,所述N个虚拟机管理器与所述N类物理处理器核心——对应;或者
[0009]根据所述N类物理处理器核心的种类和同一种类的处理器核心之间的互联类型部署所述M个虚拟机管理器;或者
[0010]根据所述N类物理处理器核心的种类、同一种类的处理器核心之间的互联类型以及同一互联类型的处理器核心的数量部署所述M个虚拟机管理器。
[0011]结合第一方面或第一方面的第一种可能的实现方式,在第一方面的第二种可能的实现方式中,所述控制器还用于在每个所述虚拟机管理器管理的物理处理器核心区中确定部分核心区以运行对应的虚拟机管理器。
[0012]结合第一方面的第二种可能的实现方式,在第一方面的第三种可能的实现方式中,每个所述虚拟机管理器具体用于:根据应用的类型和/或需求分配所述管理的物理处理器核心区中的另一部分核心区以运行所述应用所寄宿的客户端操作系统;其中,所述另一部分核心区和所述部分核心区不相同。
[0013]结合第一方面的第三种可能的实现方式,在第一方面的第四种可能的实现方式中,每个所述虚拟机管理器还用于:接收所述客户端操作系统发送的处理器核间中断IPI事件,处理所述IPI事件,并在处理完所述IPI事件之后,向所述客户端操作系统发送进入通知,以通知所述客户端操作系统继续运行。
[0014]结合第一方面的第四种可能的实现方式,在第一方面的第五种可能的实现方式中,所述服务器还包括与处理器核心数量一致的本地高级可编程中断控制器,分别配置给所述每个处理器核心,每个所述虚拟机管理器具体用于:在接收所述客户端操作系统发送的处理器核间中断IPI事件之前,获取每个所述虚拟机管理器自身所管理的物理处理器核心对应的本地高级可编程中断控制器的标识信息,并将所述标识信息发送给运行在自身所管理的物理处理器核心上的客户端操作系统,以使所述客户端操作系统根据所述标识信息发送所述IPI事件。
[0015]结合第一方面的第五种可能的实现方式,在第一方面的第六种可能的实现方式中,每个所述虚拟机管理器还用于:为每个所述虚拟机管理器所管理的物理处理器核心区分配I/O高级可编程中断控制器;并配置所述I/O高级可编程中断控制器的重定向表;在接收到外部中断信息时,通过所述重定向表将所述外部中断信息分发到对应的本地高级可编程中断控制器中。
[0016]结合第一方面或第一方面的第一种可能的实现方式至第一方面的第六种可能的实现方式中的任意一种,在第一方面的第七种可能的实现方式中,每个所述虚拟机管理器还用于:向其他虚拟机管理器发送自身所管理的物理处理器核心的信息;接收所述其他虚拟机管理器发送的所述其他虚拟机管理器所管理的物理处理器核心的信息并将所述M个虚拟机管理器所管理的物理处理器核心的信息发送给上层管理平台,以使得所述上层管理平台根据所述信息将应用的部署请求发送给匹配的虚拟机管理器。
[0017]本申请第二方面提供一种资源管理方法,包括:
[0018]虚拟机管理器接收应用的部署请求,所述请求中包括所述应用的类型和/或需求;其中,虚拟机管理器管理一个物理处理器核心区,所述物理处理器核心区为服务器上的N类物理处理器核心中的一类;所述虚拟机管理器为根据所述N类物理处理器核心的种类部署的M个虚拟机管理器中的一个;所述虚拟机管理器运行在所述物理处理器核心区的部分核心区上;
[0019]所述虚拟机管理器根据所述类型和/或需求分配所述物理处理器核心区的另一部分核心区以运行所述应用所寄宿的客户端操作系统;其中,所述另一部分核心区和所述部分核心区不相同。
[0020]结合第二方面,在第二方面的第一种可能的实现方式中,所述方法还包括:
[0021]所述虚拟机管理器接收所述客户端操作系统发送的处理器核间中断IPI事件;
[0022]所述虚拟机管理器处理所述IPI事件;
[0023]所述虚拟机管理器在处理完所述IPI事件之后,向所述客户端操作系统发送进入通知,以通知所述客户端操作系统继续运行。
[0024]结合第二方面的第一种可能的实现方式,在第二方面的第二种可能的实现方式中,所述服务器还包括与每个处理器核心数量一致的本地高级可编程中断控制器,分别配置给所述每个处理器核心,所述方法还包括:
[0025]所述虚拟机管理器获取所述虚拟机管理器所管理的物理处理器核心对应的本地高级可编程中断控制器的标识信息;
[0026]所述虚拟机管理器将所述标识信息发送给所述客户端操作系统,以使所述客户端操作系统根据所述标识信息发送所述IPI事件。
[0027]结合第二方面的第二种可能的实现方式,在第二方面的第三种可能的实现方式中,所述方法还包括:
[0028]所述虚拟机管理器为所述虚拟机管理器所管理的物理处理器核心区分配I/O高级可编程中断控制器;并配置所述I/o高级可编程中断控制器的重定向表;在接收到外部中断信息时,通过所述重定向表将所述外部中断信息分发到对应的本地高级可编程中断控制器中。
[0029]结合第二方面或第二方面的第一种可能的实现方式至第二方面的第三种可能的实现方式中的任意一种,在第一方面的第四种可能的实现方式中,所述方法还包括:
[0030]所述虚拟机管理器向其他虚拟机管理器发送自身所管理的物理处理器核心的信息;接收所述其他虚拟机管理器发送的所述其他虚拟机管理器所管理的物理处理器核心的信息并将所述M个虚拟机管理器所管理的物理处理器核心的信息发送给上层管理平台,以使得所述上层管理平台根据所述信息将应用的部署请求发送给匹配的虚拟机管理器。
[0031]本申请第三方面提供一种虚拟机管理器,所述虚拟机管理器管理一个物理处理器核心区,所述物理处理器核心区为服务器上的N类物理处理器核心中的一类;所述虚拟机管理器为根据所述N类物理处理器核心的种类部署的M个虚拟机管理器中的一个;所述虚拟机管理器运行在所述物理处理器核心区的部分核心区上;所述虚拟机管理器包括:
[0032]分区及管理模块,用于接收应用的部署请求,所述请求中包括所述应用的类型和/或需求;并根据所述类型和/或需求分配所述物理处理器核心区的另一部分核心区以运行所述应用所寄宿的客户端操作系统;其中,所述另一部分核心区和所述部分核心区不相同。
[0033]结合第三方面,在第三方面的第一种可能的实现方式中,所述分区及管理模块还用于:接收所述客户端操作系统发送的处理器核间中断IPI事件;处理所述IPI事件;并在处理完所述IPI事件之后,向所述客户端操作系统发送进入通知,以通知所述客户端操作系统继续运行。
[0034]结合第三方面的第一种可能的实现方式,在第三方面的第二种可能的实现方式中,所述服务器还包括与每个处理器核心数量一致的本地高级可编程中断控制器,分别配置给所述每个处理器核心,所述虚拟机管理器还包括:
[0035]中断定向分发模块,用于获取所述虚拟机管理器所管理的物理处理器核心对应的本地高级可编程中断控制器的标识信息;并将所述标识信息发送给所述客户端操作系统,以使所述客户端操作系统根据所述标识信息发送所述IPI事件。
[0036]结合第三方面的第二种可能的实现方式,在第三方面的第三种可能的实现方式中,所述中断定向分发模块还用于:为所述虚拟机管理器所管理的物理处理器核心区分配I/O高级可编程中断控制器;并配置所述I/O高级可编程中断控制器的重定向表;在接收到外部中断信息时,通过所述重定向表将所述外部中断信息分发到对应的本地高级可编程中断控制器中。
[0037]结合第三方面或第三方面的第一种可能的实现方式至第三方面的第三种可能的实现方式中的任意一种,在第一方面的第四种可能的实现方式中,所述虚拟机管理器还包括:
[0038]交互模块,用于向其他虚拟机管理器发送所述虚拟机管理器所管理的物理处理器核心的信息;接收所述其他虚拟机管理器发送的所述其他虚拟机管理器所管理的物理处理器核心的信息并将所述M个虚拟机管理器所管理的物理处理器核心的信息发送给上层管理平台,以使得所述上层管理平台根据所述信息将应用的部署请求发送给匹配的虚拟机管理器。