CN114461379A - 一种云桌面系统的虚拟硬件配置分配方法 - Google Patents
一种云桌面系统的虚拟硬件配置分配方法 Download PDFInfo
- Publication number
- CN114461379A CN114461379A CN202111613355.4A CN202111613355A CN114461379A CN 114461379 A CN114461379 A CN 114461379A CN 202111613355 A CN202111613355 A CN 202111613355A CN 114461379 A CN114461379 A CN 114461379A
- Authority
- CN
- China
- Prior art keywords
- hardware configuration
- terminal
- virtual hardware
- server
- 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.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5061—Partitioning or combining of resources
- G06F9/5077—Logical partitioning of resources; Management or configuration of virtualized resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/451—Execution arrangements for user interfaces
- G06F9/452—Remote windowing, e.g. X-Window System, desktop virtualisation
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Stored Programmes (AREA)
Abstract
本发明涉及一种云桌面系统的虚拟硬件配置分配方法,包括:接收来自云桌面系统客户端的终端硬件配置;确定与所述终端硬件配置最为接近的服务器镜像对应的虚拟硬件配置,其中所述虚拟硬件配置的计算能力低于所述终端硬件配置的计算能力;响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于20%,在服务器上建立基于所述终端硬件配置的新的镜像;以及将所述新的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。本申请在服务器允许的情况下,通过创建新的镜像确定与终端硬件配置最接近的虚拟硬件配置,提高终端硬件配置与虚拟硬件的匹配度,优化用户的使用体验。
Description
技术领域
本发明涉及一种计算机网络技术领域,特别地涉及一种云桌面系统的虚拟硬件配置分配方法。
背景技术
随着多年的技术发展,云桌面系统已经比较成熟。传统的云桌面系统是指用户的桌面系统都存储在服务器上。通过远程服务器实现对于用户桌面系统d统一管理,动态发放与运行,灵活分配与回收。例如,VDI(Virtual Desktop Infrastructure)就是典型的云桌面系统,所有运行都在服务器端进行,瘦终端仅提供网络连接与交互功能。然而,基于VDI的云桌面系统对于网络严重依赖,脱机使用非常困难。而且,VDI对外围设备的支持也非常有限。因此,用户体验不佳。
在PC平台计算能力日益增强的背景下,Intel公司提出了云桌面系统的IDV(Intelligent Desktop Virtualization)模式。IDV采取分布式运算,利用本地的计算资源,也可以提供更好的带宽体验和外围设备的兼容性,并且能够支持断网运行。
然而,对于从已有大量计算机的计算机网络转向云桌面系统时,由于已有的计算机网络中各种型号的计算机都存在,IDV在云端需要针对每种型号的计算机都创建对应的镜像,云桌面系统的管理和维护变得非常复杂和繁重。这使得已有的计算机网络转向云桌面系统变得成本过高,影响了云桌面系统的推广和使用。并且,创建的镜像与终端硬件配置的差异太大,无法满足终端硬件的日常需求。
发明内容
针对现有技术中存在的技术问题,本发明提出了一种云桌面系统的虚拟硬件配置分配方法,包括:接收来自云桌面系统客户端的终端硬件配置;确定与所述终端硬件配置最为接近的服务器镜像对应的虚拟硬件配置,其中所述虚拟硬件配置的计算能力低于所述终端硬件配置的计算能力;响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于20%,在服务器上建立基于所述终端硬件配置的新的镜像;以及将所述新的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
如上所述的方法,进一步包括:响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于15%或10%,在服务器上建立基于所述终端硬件配置的新的镜像。
如上所述的方法,进一步包括:确定服务器上镜像对应的虚拟硬件配置数量或者镜像数量是否超过预定阈值;响应于未超过所述预定阈值,在服务器上建立基于所述终端硬件配置的新的镜像;以及将所述新的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
如上所述的方法,进一步包括:响应于超过所述预定阈值,将已有的最为接近的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
如上所述的方法,进一步包括:确定服务器镜像对应的第一虚拟硬件配置被使用的终端数量是否超过预定数量;响应于超过预定数量,在服务器建立新的第二虚拟硬件配置。
如上所述的方法,其中所述第二虚拟硬件配置的计算能力高于所述第一虚拟硬件配置的计算能力。
如上所述的方法,进一步包括:将终端硬件配置与第二虚拟硬件配置更接近的终端的虚拟硬件配置更新为第二虚拟硬件配置。
如上所述的方法,进一步包括:响应于确定服务器上镜像对应的虚拟硬件配置数量或者镜像数量超过预定阈值,删除服务器上镜像对应的虚拟硬件配置被终端使用最少的虚拟硬件配置。
如上所述的方法,进一步包括:将使用被删除的服务器上镜像对应的虚拟硬件配置的终端的虚拟硬件配置更新为现有的与其终端硬件配置最接近的虚拟硬件配置。
如上所述的方法,其中所述终端硬件配置包括被提升后的硬件配置。
本申请在服务器允许的情况下,通过创建新的镜像确定与终端硬件配置最接近的虚拟硬件配置,提高终端硬件配置与虚拟硬件的匹配度,优化用户的使用体验。
附图说明
下面,将结合附图对本发明的优选实施方式进行进一步详细的说明,其中:
图1是根据本发明的一个实施例的云桌面系统的结构示意图;
图2是根据本发明的一个实施例的终端的系统结构示意图;
图3是根据本发明的一个实施例的云桌面系统客户端的运行流程示意图;
图4是根据本发明的一个实施例的云桌面系统的服务器的流程示意图;
图5是根据本发明的一个实施例的云桌面系统的虚拟硬件配置分配方法的流程示意图;以及
图6是根据本发明的另一个实施例的云桌面系统的虚拟硬件配置分配方法的流程示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
在以下的详细描述中,可以参看作为本申请一部分用来说明本申请的特定实施例的各个说明书附图。在附图中,相似的附图标记在不同图式中描述大体上类似的组件。本申请的各个特定实施例在以下进行了足够详细的描述,使得具备本领域相关知识和技术的普通技术人员能够实施本申请的技术方案。应当理解,还可以利用其它实施例或者对本申请的实施例进行结构、逻辑或者电性的改变。
本发明提出了一种IDV基础上的云桌面系统。在计算机终端通过本地操作系统上运行虚拟化应用从云端获得虚拟化配置并模拟出相应的硬件。在模拟硬件的基础上进行二次虚拟化通过IDV框架分发云桌面,从而实现全网络的云桌面系统。由于虚拟化配置类型的数量是可控的,云端的云桌面维护工作将是可预测的。这将促进云桌面系统在已有计算机网络的布置和推广。
图1是根据本发明的一个实施例的云桌面系统的结构示意图。如图所示,云桌面系统100包括服务器101以及与其连接的多个终端102-107。终端102和103在第一局域网中,而终端104和105在第二局域网中;而终端102和103与终端104和105并不在同一局域网中。终端106和107分别通过VPN与服务器101连接。
在一些实施例中,服务器101包括一个或多个处理器、存储器和通信接口。处理器能够通过高速总线被耦合到存储器和通信接口。处理器包括一个或多个中央处理单元(CPU)、图形处理单元(GPU)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或它们的组合。处理器能够执行存储在存储器中的软件或计算机可读指令以执行本文描述的方法或操作。存储器能够存储软件、数据、日志或它们的组合。存储器可以是内部存储器或外部存储器。内部存储器的例子诸如磁盘存储器、闪存、非易失性随机存取存储器(NVRAM)等。外部存储器的例子诸如驻留在存储节点、云服务器或存储服务器上的存储器。通信接口的例子包括网络接口卡、调制解调器等。服务器101能够使用通信接口连接到第一局域网和第二局域网,与分别处于其中的终端102-105通信。服务器也能够使用通信接口通过VPN协议与处于外部网络中的终端106和107通信。
在一些实施例中,终端102-107中任意一者包括:第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标;其中,第一I/O设备可以包括第一硬盘和第二网络接口卡。以上这些设备都是各个终端的物理设施。如所理解的,终端102-107上经配置以运行第一操作系统,即本地操作系统。这些操作系统包括但不限于Windows、Linux、Mac OS、IOS或者Android或者基于这些操作系统的其他操作系统,例如麒麟(Kylin)、红旗linux、AliOS(原Yun OS)、鸿蒙(Harmony OS)等。终端102-107在购买时,很多已经包括了第一操作系统。在一些情况下,终端102-107的硬件和第一操作系统等的维护服务也是可以独立地有终端102-107的品牌服务商或其他机构提供的。因此,在一些实施例中,云桌面系统的维护不必包括终端102-107的硬件以及第一操作系统的维护工作。
在一些实施例中,终端102-107中任意一者进一步包括第一虚拟化层、第二虚拟化层、以及云桌面。第一虚拟化层是在第一操作系统中通过虚拟化方式产生的,其包括了多个虚拟硬件:第二处理器、第二RAM、第二I/O设备、第二显示器、以及第二键盘和第二鼠标;其中,第二I/O设备可以包括第二硬盘和第二网络接口卡;其可以与第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标相同,也可以与它们不同。第二虚拟化层是在第一虚拟化层的虚拟硬件基础上运行的虚拟化软件。在IDV框架下,第二虚拟化层的虚拟化软件与IDV的本地虚拟化软件作用相似,提供对其上的云桌面的支持。不同之处在于,在本发明中IDV虚拟化软件是运行在第一虚拟化层的各个虚拟化硬件上的。云桌面即为在终端上运行的第二操作系统,其包括但不限于Windows、Linux、Mac OS、IOS或者Android或者基于这些操作系统的其他操作系统,例如麒麟(Kylin)、红旗linux、AliOS(原Yun OS)、鸿蒙(Harmony OS)等。
在终端的二次虚拟化为云桌面系统提供了极大的灵活性。虽然经过了二次虚拟化,但是对于本地计算性能的损失并不大。而且,在相同的框架下也能够实现本地终端的性能提升。在一些实施例中,如果终端本身的硬件,例如第一处理器、第一RAM等不支持IDV框架下的虚拟化软件,第一虚拟化层可以通过虚拟化的手段提升第一处理器、第一RAM等硬件并通过服务器101的资源来支持客户端的提升。例如,终端的第一处理器为2016年之前的Intel i3处理器并不支持Intel Broadwell,无法运行IDV框架。在第一虚拟化层可以通过虚拟化手段将虚拟的第二处理器设置为Intel i5-5675C,通过服务器端的计算资源来达到所需的计算能力。这样既使得IDV框架能够方便地在老旧的终端上顺利安装和运行,也能够实质上地提升终端的用户体验。
在终端的二次虚拟化也为云桌面系统的维护减轻了负担。由于虚拟化硬件配置是云端服务器分发的,从服务器端可以控制终端镜像的数量。由此,能够极大地减轻云桌面系统的维护工作,减少云桌面系统的实际运行成本。
服务器运行云管理平台软件,以提供云桌面系统的管理功能。在一些实施例中,服务器包括镜像库110和云桌面管理模块112;其中镜像库110中保存一个或多个与终端相关的镜像。在一些实施例中,多个终端可以对应一个镜像。镜像数量的减少能够减轻镜像所需的维护工作。在另一些实施例中,镜像库110中包括基础镜像和多个增量镜像。基础镜像对应于虚拟硬件配置。针对不同的虚拟硬件配置存在不同的基础镜像。增量镜像对应于终端。每个终端都有在镜像库中的增量镜像。增量镜像中存储终端在基础镜像基础上的个性化更新。基础镜像数量较少,这既可以减少维护的工作量,也提供了终端个性化设置的灵活性。
云桌面管理模块112提供针对云桌面系统的管理功能。在一些实施例中,云桌面管理模块112提供针对镜像库中镜像的管理,其包括但不限于:创建新的镜像、将镜像与终端绑定、更新以及删除镜像等。在一些实施例中,云桌面管理模块112提供针对终端的管理,其包括但不限于:增加和删除终端、配置网络、设定管理策略、数据的备份和恢复等。这些功能与现有IDV框架中的管理功能类似,这里不再赘述。
与现有IDV框架不同,云桌面管理模块112还提供虚拟硬件配置的管理功能。云桌面管理模块接收来自终端的虚拟硬件配置请求。虚拟硬件配置请求中至少包括终端的硬件配置:第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标等。云桌面管理模块选择已有的多个虚拟硬件配置中适于所述终端的虚拟硬件配置,并将该虚拟硬件配置发送给该终端。如所理解的,虚拟硬件配置既可能在计算和存储能力等方面低于终端硬件配置;也可能在计算和存储能力等方面高于终端硬件配置。为了尽可能充分利用终端本地计算和存储资源而节约云端的计算和存储资源,虚拟硬件配置的计算和存储能力一般低于终端硬件配置的能力。
在一些实施例中,服务器还包括安全认证服务模块114。安全认证服务模块114提供终端与服务器之间的接入服务;其包括但不限于用户服务、登录认证服务、传输加密服务、流量控制服务等。这些功能与现有IDV框架中的相关功能类似,这里不再赘述。
在一些实施例中,服务器还包括云计算管理模块116和云资源管理模块118。当终端的硬件提供的计算或存储能力不足时,虚拟的第二处理器、第二RAM或第二I/O等利用服务器提供的云端计算和存储能力为终端提供服务。因此,服务器上需要根据虚拟硬件配置提供相应的资源以支持云端的计算和存储。进一步地,服务器本身还要管理多个终端及其提供相应的云端服务,也需要计算和存储资源。云计算管理模块116和云资源管理模块118提供和分配云端计算和存储所需的资源并对云计算进行管理。
图2是根据本发明一个实施例的终端的系统结构示意图。如图所示,终端包括了5层结构,分别是基础硬件层、本地操作系统层、第一虚拟化层、第二虚拟化层和云桌面层。基础硬件层是指终端所具有的硬件,包括第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标等。本地操作系统层(即第一操作系统)是指运行在基础硬件层上的本地操作系统,其可以为Windows、Linux、Mac OS、IOS或者Android或者基于这些操作系统的其他操作系统,例如麒麟(Kylin)、红旗linux、AliOS(原Yun OS)、鸿蒙(Harmony OS)等。
在一些实施例中,终端能够通过安装软件或者APP的方式在本地操作系统层运行本发明的云桌面系统的客户端。如所理解的,本发明的客户端根据本地操作系统的不同以不同的形式提供。例如,针对Windows系统的安装包、针对Mac OS系统的dmg文件或者pkg文件、针对Android系统的apk文件等。终端可以通过网站下载或者其他方式获得云桌面系统的客户端;并且在终端的本地操作系统上安装。
通过云桌面系统客户端,终端能够与服务器通信并获得服务器分配的虚拟硬件设置,并在终端的本地操作系统之上虚拟出对应的硬件。这些虚拟硬件形成第一虚拟化层,包括:第二处理器、第二RAM、第二I/O设备、第二显示器、以及第二键盘和第二鼠标等。
终端在第一虚拟化层的虚拟硬件基础上部署IDV框架以远程运行云桌面。如所了解的,在第一虚拟化层之上设置第二虚拟化层,即超级管理程序(Hypervisor)。Hypervisor直接运行在虚拟硬件上提供虚拟硬件所需要的驱动或者至少CPU、Interrupt(终端)和RAM的驱动,例如XEN。由于Hypervisor能够直接运行在虚拟硬件之上,虽然是同样是虚拟化但是性能的损失相对较小,能够保证运行的可靠性。Hypervisor管理其上运行的第二操作系统。第二操作系统可以为Windows、Linux、Mac OS、IOS或者Android或者基于这些操作系统的其他操作系统,例如麒麟(Kylin)、红旗linux、AliOS(原Yun OS)、鸿蒙(Harmony OS)等。第二虚拟化层与第二操作系统层与已有的IDV框架的技术类似,这里不再赘述。
图3是根据本发明一个实施例的云桌面系统客户端的运行流程示意图。如图所示,当云桌面系统客户端在终端的本地操作系统中安装完成后,云桌面系统客户端运行并执行以下步骤:在步骤310,获得终端的硬件配置,即第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标等。在步骤320,将终端硬件配置发送到服务器。这些硬件配置至少包括第一处理器和第一RAM。在一些实施例中,这些配置还包括第一I/O设备。如所理解的,发送到服务器的终端的硬件配置中还可以包括其他硬件,例如显示器、打印机、扫描仪等。
在步骤330,接收来自服务器的虚拟硬件配置。虚拟硬件配置至少包括第二处理器和第二RAM。在一些实施例中,虚拟硬件配置还包括第二I/O设备。如所理解的,发送到终端的虚拟硬件配置中还可以包括其他虚拟硬件,例如显示器、打印机、扫描仪等。服务器收到来自终端的硬件配置后,首先确定终端的硬件配置能否运行云桌面系统以及运行云桌面系统的性能。由此,服务器端确定终端的硬件配置是否需要提升,即是否需要利用云端的计算资源来提升终端的运行体验。如果需要提升计算能力,则服务器端确定提升后指定给该终端的处理器类型和RAM数量。接下来,服务器根据终端的硬件配置以及如果有提升的情况下指定的处理器类型和RAM数量,确定分配给该终端的虚拟硬件配置。对于其他需要提升的终端硬件类型,例如存储空间等,也可以通过类似的方式进行。
在一些实施例中,服务器维持着一定数量的虚拟硬件配置。服务器根据终端的硬件配置以及经指定的处理器类型和RAM数量将其中的一个虚拟硬件配置分配给该终端。如所理解的,各个虚拟硬件配置对应着不同的镜像。这样,在服务器端能够维持数量可控的镜像数量。
在步骤340,根据虚拟硬件配置,在终端模拟出对应的各个虚拟硬件。云桌面系统的客户端具有以软件来模拟硬件的功能。云桌面系统客户端的这一功能类似于VMwareWorkstation或者Visual Box的功能,即通过软件来生成虚拟硬件。在一些实施例中,在无需服务器的计算资源时,针对虚拟硬件的通信被转移给本地操作系统,再由本地的硬件执行。在其他一些实施例中,在需要利用服务器的计算资源时,针对虚拟处理器和RAM的通信被发送给服务器并从服务器接收计算的结果。在需要服务器的存储资源时,针对存储的通信例如对硬盘的读写请求将被发送给服务器并从服务器接收读写的结果。
在步骤350,在虚拟硬件配置基础上设置IDV框架的客户端。在一些实施例中,在虚拟硬件的基础上安装Hypervisor,例如XEN。然后,在终端上通过Hypervisor安装IDV云桌面客户端。根据终端的需要选择合适的第二操作系统,即云桌面。由此,实现终端上的两次虚拟化以及云桌面的运行。在此步骤中,上述过程与已有的IDV框架客户端设置方式类似,这里不再赘述。
图4是根据本发明一个实施例的云桌面系统的服务器的流程示意图。如图所示,云桌面系统的服务器的流程包括如下步骤:在步骤410,接收来自终端的硬件配置。如前所述,终端的硬件配置包括:第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标等。在步骤420,确定终端的硬件配置是否需要提升。在一些实施例中,服务器判断终端能否满足运行IDV框架的条件。如果终端的计算能力或者处理器类型等不满足安装IDV框架客户端的条件,那么在服务器将提升终端的计算能力。在一些实施例中,如果终端的存储能力不足,例如存储空间太小,那么服务器将提升终端的存储能力。在一些实施例中,在步骤430,服务器判断终端提供的性能体验是否能够达到最低标准。这些性能体验包括但不限于终端执行一些任务的等待时间、终端的图形或视频渲染能力、终端的存储能力等。如果服务器确定终端提供的性能体验无法达到最低标准,服务器将提升终端的计算能力和/或存储能力。
在步骤440,服务器确定为终端提供的计算能力和/或存储能力。在一些实施例中,如果是提升终端的计算能力,服务器确定虚拟终端的处理器类型和RAM大小。例如,服务器根据运行IDV框架的最低硬件标准或者性能体验的最低标准决定处理器的类型和RAM。如果是提升终端的存储能力,服务器确定提供的云端存储空间的大小。例如,根据终端的需求分配云端的存储空间给终端。
在步骤450,服务器确定终端的虚拟硬件配置。在一些实施例中,服务器的镜像库中存储多个镜像。各个镜像对应多个虚拟硬件配置。在另外一些实施例中,镜像库中的镜像包括基本镜像和增量镜像。基本镜像对应虚拟硬件配置。由此,服务器包括多个虚拟硬件配置。在一些实施例中,服务器将终端的硬件配置与多个虚拟硬件配置比较,将与终端硬件配置最为接近的虚拟硬件配置分配给终端。在一些实施例中,虚拟硬件配置中CPU的处理能力小于或等于终端硬件中CPU的处理能力。虚拟硬件配置中RAM的大小等于终端硬件中RAM的大小。虚拟硬件配置中硬盘空间的大小等于终端硬件中硬盘空间的大小。当然,虚拟RAM和硬盘空间的大小也可以略小于终端RAM和硬盘空间的大小。一般情况下,虚拟CPU处理能力、RAM和硬盘空间的大小都不会超过终端CPU处理能力、RAM和硬盘空间的大小。
在一些实施例中,服务器将利用提升的计算能力和/或存储能力代替终端对应的硬件,然后与多个虚拟硬件配置比较,确定分配给终端的虚拟硬件配置。由于终端的计算能力和/或存储能力被提升,而提升后的计算能力和/或存储能力与已有的多个虚拟硬件配置中的计算能力和/或存储能力对应。因此,终端的计算能力和/或存储能力提升后,能够容易地确定对应的虚拟硬件配置。
在一些实施例中,如果服务器上没有适合终端的虚拟硬件配置,服务器上可以建立新的虚拟硬件配置,并在镜像库中建立对应的镜像。然后,将新建立的虚拟硬件配置分配给终端。如果终端的计算能力和/或存储能力超过服务器上已有的虚拟硬件配置,建立新的虚拟硬件配置,从而不会使得终端的计算能力和/或存储能力无法充分发挥。
在步骤460,指定与终端相关的镜像。服务器根据终端的计算能力和/或存储能力确定适合于该终端运行的镜像。在一些实施例中,服务器获得终端所需的操作系统的类型,在适合于该终端运行的镜像中挑选与终端所需的操作系统的镜像。例如,如果终端采用Windows XP系统,则在该终端的虚拟硬件配置所对应的镜像中选择Windows XP的镜像或基础镜像指定给该终端。之后,终端下载指定的镜像并运行Windows XP的云桌面。
在一些实施例中,服务器通过对终端指定的镜像进行管理,以远程管理终端的云桌面。例如,服务器可以通过更改指定给终端的镜像改变终端使用的操作系统。服务器可以通过镜像中安装新的软件,在终端的第二操作系统中增加新的软件。服务器可以通过在镜像中增加终端硬件的驱动,在第二操作系统中增加新的硬件。服务器可以通过在镜像中配置登录信息,管理使用终端的用户。服务器可以通过在镜像中配置用户权限,管理使用终端用户的权限。服务器对于各个终端云桌面的管理与现有IDV框架下的管理方法类似,这里不再赘述。
本发明通过在计算机终端模拟的虚拟硬件运行IDV框架,实现云桌面的分发和管理。在本发明的一些实施例中,能够有效地减少服务器上管理的镜像的数量,从而减轻云桌面维护工作量,促进云桌面系统在已有计算机网络的布置和推广。在本发明的一些实施例中,通过服务器提供的计算能力和/或存储能力提升终端的虚拟硬件,从而流畅地运行云桌面系统。不但能够扩大云桌面系统的适用范围,而且也能够提升使用云桌面系统的用户体验。
图5是根据本发明一个实施例的云桌面系统的虚拟硬件配置分配方法的流程示意图。如图所示,云桌面系统的虚拟硬件配置分配方法的流程包括如下步骤:在步骤510,接收来自云桌面系统客户端的终端硬件配置。终端硬件配置包括:第一处理器、第一RAM、第一I/O设备、第一显示器、以及第一键盘和第一鼠标等。
在步骤520,确定与终端硬件配置最为接近的服务器镜像对应的虚拟硬件配置。其中所述虚拟硬件配置的计算能力低于终端硬件配置的计算能力。虚拟硬件配置的计算能力低于终端硬件配置的计算能力,能够保证终端流畅运行云桌面系统。
在步骤530,判断最为接近的服务器镜像对应的虚拟硬件配置的计算能力与终端硬件配置的计算能力之间的差异是否大于计算阈值;其中计算阈值可以是20%、15%或者10%。计算阈值越大,虚拟硬件配置的计算能力与终端硬件配置的计算能力差异就越大。二者的差异太大时,不利于发挥终端硬件的最佳性能,造成计算资源的浪费。匹配的虚拟硬件配置计算能力太低时,无法满足正常的用户需求,降低用户满意度。
在步骤540,响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异小于或等于计算阈值,将已有的最为接近的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。当虚拟硬件配置与终端硬件配置的计算能力差异不太大时,说明虚拟硬件配置与终端配置的计算能力大致相当,既能够保证终端上流畅运行云桌面系统,又能够释放终端硬件的最佳性能。
在步骤550,响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于计算阈值,判断服务器上镜像对应的虚拟硬件配置数量或者镜像数量是否超过预定阈值。镜像库中存储多个镜像。各个镜像对应多个虚拟硬件配置。为了减少云端管理员的管理工作,镜像数量和虚拟硬件配置数量控制在一定数量以内。镜像数量的减少使得云端管理员管理的对象减少,从而能够使得有限的管理员数量能够支持更多的用户终端。
在一个实施例中,响应于服务器上镜像对应的虚拟硬件配置数量或者镜像数量超过预定阈值,执行步骤540,将已有的最为接近的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。这样并不会增加镜像的数量,从而将镜像数量锁定在预定阈值之下。
在另一个实施例中,响应于服务器上镜像对应的虚拟硬件配置数量或者镜像数量超过预定阈值,执行步骤560,删除服务器上镜像对应的虚拟硬件配置被终端使用最少的虚拟硬件配置。使用最少的虚拟硬件配置,说明该种虚拟硬件配置对应的终端较少,删除使用较少的虚拟硬件配置,能够有效减少由该种虚拟硬件配置造成的利用率过低的问题。这样,各个镜像对应的终端数量也能更加平均。
在步骤570,将使用被删除的服务器上镜像对应的虚拟硬件配置的终端的虚拟硬件配置更新为现有的与其终端硬件配置最接近的虚拟硬件配置。为了保证被删除的虚拟硬件配置对应的终端能够正常工作,还需要重新分配一个计算能力相近的虚拟硬件配置给终端。其中所述终端硬件配置包括被提升后的硬件配置。当被删除的虚拟硬件配置对应的终端存在提升硬件配置的需求,服务器依然提供计算资源和/或存储资源,提升终端的硬件配置。
在步骤580,响应于服务器上镜像对应的虚拟硬件配置数量或者镜像数量未超过预定阈值,在服务器上建立基于终端硬件配置的新的镜像。在步骤590,将新的镜像对应的虚拟硬件配置分配给云桌面系统客户端。
当服务器上镜像对应的虚拟硬件配置数量或镜像数量未超过预定阈值时,说明云端管理员管理的镜像数量尚处于能够接受的程度。在服务器上根据终端硬件配置增加一个新的镜像,新的镜像中的虚拟硬件配置与终端硬件配置的计算能力更加接近,有利于给用户提供最佳性能的虚拟硬件配置。本申请在服务器有空闲资源情况下,根据终端硬件配置建立新的镜像,以更好的适配终端硬件配置,提高用户的使用满意度。
服务器中存储有多个镜像,每个镜像中包括多个虚拟硬件配置。在镜像数量和虚拟硬件配置总数量有限时,虚拟硬件配置利用率却可能不尽相同。有些热门的虚拟硬件配置对应的镜像被使用的终端数量过多,同样会带来云端管理员管理上的问题。针对上述问题,本申请提出新的解决方案。
图6是根据本发明另一个实施例的云桌面系统的虚拟硬件配置分配方法的流程示意图。在步骤610,响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与终端硬件配置的计算能力之间的差异小于或等于计算阈值时,执行步骤620,判断最为接近的服务器镜像对应的第一虚拟硬件配置被使用的终端数量是否超过预定数量。预定数量可以根据服务器服务终端总数量决定,预定数量还可以根据实际需求,工作人员进行自行设定。
在步骤630,响应于最为接近的服务器镜像对应的第一虚拟硬件配置被使用的终端数量未超过预定数量,将最为接近的镜像对应的虚拟硬件配置分配给云桌面系统客户端。
在步骤640,响应于最为接近的服务器镜像对应的第一虚拟硬件配置被使用的终端数量超过预定数量,在服务器建立新的第二虚拟硬件配置。其中第二虚拟硬件配置的计算能力可以高于所述第一虚拟硬件配置的计算能力。终端数量超过预定数量,将大幅度增加云端管理员的维护工作。因此,通过创建新的虚拟硬件配置有利于平衡多个虚拟硬件配置之间的数量,均衡多个虚拟硬件配置的维护任务,优化使用体验。
在步骤650,将终端硬件配置与第二虚拟硬件配置更接近的终端的虚拟硬件配置更新为第二虚拟硬件配置。根据终端硬件配置的计算能力更新第二虚拟硬件配置。在步骤660,将第二虚拟硬件配置分配给云桌面客户端。
举例而言,镜像库中某一镜像对应5个虚拟硬件配置,5个虚拟硬件配置被终端使用数量如下表所示:
由上表可知,1号虚拟硬件配置有65个终端使用,2号虚拟硬件配置有44个终端使用,3号虚拟硬件配置有211个终端使用,4号虚拟硬件配置有55个终端使用,5号虚拟硬件配置有89个终端使用。显然,3号虚拟硬件配置比较热门,3号虚拟硬件配置被使用量是其他虚拟硬件配置的数倍,造成虚拟硬件配置使用不均匀问题。因此可以在服务器建立与热门虚拟硬件配置接近的新的虚拟硬件配置以均衡虚拟硬件配置的使用数量,提高虚拟硬件配置对应终端的使用体验。本申请根据虚拟硬件配置被使用的数量动态调整虚拟硬件配置的数量,能够均衡各个虚拟配置对应的维护工作量,使得云桌面系统的管理更加方便。
上述实施例仅供说明本发明之用,而并非是对本发明的限制,有关技术领域的普通技术人员,在不脱离本发明范围的情况下,还可以做出各种变化和变型,因此,所有等同的技术方案也应属于本发明公开的范畴。
Claims (10)
1.一种云桌面系统的虚拟硬件配置分配方法,包括:
接收来自云桌面系统客户端的终端硬件配置;
确定与所述终端硬件配置最为接近的服务器镜像对应的虚拟硬件配置,其中所述虚拟硬件配置的计算能力低于所述终端硬件配置的计算能力;
响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于20%,在服务器上建立基于所述终端硬件配置的新的镜像;以及
将所述新的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
2.根据权利要求1所述的方法,进一步包括:响应于最为接近的服务器镜像对应的虚拟硬件配置的计算能力与所述终端硬件配置的计算能力之间的差异大于15%或10%,在服务器上建立基于所述终端硬件配置的新的镜像。
3.根据权利要求1所述的方法,进一步包括:确定服务器上镜像对应的虚拟硬件配置数量或者镜像数量是否超过预定阈值;响应于未超过所述预定阈值,在服务器上建立基于所述终端硬件配置的新的镜像;以及将所述新的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
4.根据权利要求3所述的方法,进一步包括:响应于超过所述预定阈值,将已有的最为接近的镜像对应的所述虚拟硬件配置分配给所述云桌面系统客户端。
5.根据权利要求1所述的方法,进一步包括:确定服务器镜像对应的第一虚拟硬件配置被使用的终端数量是否超过预定数量;响应于超过预定数量,在服务器建立新的第二虚拟硬件配置。
6.根据权利要求5所述的方法,其中所述第二虚拟硬件配置的计算能力高于所述第一虚拟硬件配置的计算能力。
7.根据权利要求6所述的方法,进一步包括:将终端硬件配置与第二虚拟硬件配置更接近的终端的虚拟硬件配置更新为第二虚拟硬件配置。
8.根据权利要求3所述的方法,进一步包括:响应于确定服务器上镜像对应的虚拟硬件配置数量或者镜像数量超过预定阈值,删除服务器上镜像对应的虚拟硬件配置被终端使用最少的虚拟硬件配置。
9.根据权利要求8所述的方法,进一步包括:将使用被删除的服务器上镜像对应的虚拟硬件配置的终端的虚拟硬件配置更新为现有的与其终端硬件配置最接近的虚拟硬件配置。
10.根据权利要求9所述的方法,其中所述终端硬件配置包括被提升后的硬件配置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111613355.4A CN114461379A (zh) | 2021-12-27 | 2021-12-27 | 一种云桌面系统的虚拟硬件配置分配方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111613355.4A CN114461379A (zh) | 2021-12-27 | 2021-12-27 | 一种云桌面系统的虚拟硬件配置分配方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114461379A true CN114461379A (zh) | 2022-05-10 |
Family
ID=81406823
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111613355.4A Pending CN114461379A (zh) | 2021-12-27 | 2021-12-27 | 一种云桌面系统的虚拟硬件配置分配方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114461379A (zh) |
-
2021
- 2021-12-27 CN CN202111613355.4A patent/CN114461379A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20100287280A1 (en) | System and method for cloud computing based on multiple providers | |
US8832687B2 (en) | Managing quotas in a distributed virtualization environment | |
US10089100B2 (en) | Desktop image management for virtual desktops | |
US8589554B2 (en) | Intelligent and elastic resource pools for heterogeneous datacenter environments | |
CN102447723B (zh) | 客户端虚拟化架构 | |
US11385883B2 (en) | Methods and systems that carry out live migration of multi-node applications | |
US20060143617A1 (en) | Method, apparatus and system for dynamic allocation of virtual platform resources | |
CN108089913B (zh) | 一种超融合系统的虚拟机部署方法 | |
US9354858B2 (en) | Desktop image management for virtual desktops using on-demand stub creation | |
CN101207516B (zh) | 单片电路和模块系统中的管理控制器远程安装性能的改进 | |
CN101171573A (zh) | 用于网络、块和文件输入及输出的卸载堆栈 | |
CN114281444B (zh) | 一种实施云桌面客户端的布置方法 | |
CN114461380A (zh) | 一种云桌面系统的虚拟硬件配置分配方法 | |
WO2022143714A1 (zh) | 服务器系统、虚拟机创建方法及装置 | |
US9329855B2 (en) | Desktop image management for virtual desktops using a branch reflector | |
CN109995890B (zh) | 一种管理网络地址转换nat网关的方法及服务器 | |
CN114281442A (zh) | 一种云桌面客户端及其方法 | |
US11057263B2 (en) | Methods and subsystems that efficiently distribute VM images in distributed computing systems | |
US11295018B1 (en) | File system modification | |
CN114217999A (zh) | 一种云桌面系统及方法 | |
CN114461379A (zh) | 一种云桌面系统的虚拟硬件配置分配方法 | |
CN114281443B (zh) | 一种云桌面系统及方法 | |
CN114281421B (zh) | 一种云桌面系统的驱动安装方法 | |
US20240069892A1 (en) | Cloud provisioned boot volumes | |
CN114500564B (zh) | 一种云桌面系统的客户端硬件适配方法 |
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 |