KVM架构及其优点

上传人:工**** 文档编号:431786981 上传时间:2023-07-13 格式:DOC 页数:6 大小:61.50KB
返回 下载 相关 举报
KVM架构及其优点_第1页
第1页 / 共6页
KVM架构及其优点_第2页
第2页 / 共6页
KVM架构及其优点_第3页
第3页 / 共6页
KVM架构及其优点_第4页
第4页 / 共6页
KVM架构及其优点_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《KVM架构及其优点》由会员分享,可在线阅读,更多相关《KVM架构及其优点(6页珍藏版)》请在金锄头文库上搜索。

1、Linux既有良好的灵活性,在虚拟化方面同样出色。但是最近,随着内核虚拟机(KVM)的出现,Linux虚拟化的前景发生了变化KVM是构成主流Linux内核(V2.6.20)一部分的第一个虚拟化解决方案。KVM支持Linux客户操作系统的虚拟化一一甚至支持其硬件对虚拟化敏感的Windows系统的虚拟化。了解LinuxKVM的架构并了解它与内核的紧密集成为何会改变您使用Linux的方式。简介虚拟化概念很早就已出现。简单来说,虚拟化就是使用某些程序,并使其看起来类似于其他程序的过程。将这个概念应用到计算机系统中可以让不同用户看到不同的单个系统(例如,一台计算机可以同时运行Linux和Microsof

2、tWindows)。这通常称为全虚拟化(fullvirtualization)。虚拟化也可以使用更加复杂的格式,其中单个计算机看上去具有多个架构(对于一个用户来说,它是一个标准的x86平台;对于另外一个用户来说,它是IBMPowerPC平台)。这种虚拟化形式通常被称为硬件仿真。最后,更加简单的一种虚拟化是操作系统虚拟化,其中一台计算机可以运行相同类型的多个操作系统。这种虚拟化可以将一个操作系统的多个服务器隔离开来(这意味着全都必须使用相同类型和版本的操作系统)。虚拟化和准虚拟化(para-virtualization)虚拟化最常使用的两种方法是全虚拟化和准虚拟化。使用全虚拟化,在虚拟化的操作系

3、统和硬件之间存在一个层,用于决定访问。这个层称为系统管理程序或虚拟机监视器(VMM)。准虚拟化与之类似,但是系统管理程序会以一种更具协作性的方式进行操作。这是因为每个客户操作系统都了解自己正在虚拟化模式中运行,因此每个系统都与系统管理程序协作,来实现底层硬件的虚拟化。全虚拟化的例子包括商业虚拟化解决方案VMware,以及商业IBMzSeries计算机上使用的IBMSystemz9VirtualMachine(z/VM)操作系统。准虚拟化的例子有Xen和User-Mode-Linux(UML)。KVM也被认为是一个全虚拟化解决方案,不过我们稍后再介绍这个问题。虚拟化的工作原理我们首先简要介绍一下

4、虚拟化技术及其涉及的元素。虚拟化解决方案的底部是要进行虚拟化的机器。这台机器可能直接支持虚拟化,也可能不会直接支持虚拟化;那么就需要系统管理程序层的支持。系统管理程序,或称为VMM,可以看作是平台硬件和操作系统的抽象化。在某些情况中,这个系统管理程序就是一个操作系统;此时,它就称为主机操作系统,如图1所示。User-space日pplicatpn引User-sfhace(appficationE.)GuestOS(VirtuaimachineGuestOS(Virtualmachine)H/pvisQr(Virtualmoniiof)Hardware图1.虚拟化的分层抽象系统管理程序之上是客户

5、机操作系统,也称为虚拟机(VM)。这些VM都是一些相互隔离的操作系统,将底层硬件平台视为自己所有。但是实际上,是系统管理程序为它们制造了这种假象。目前使用虚拟化解决方案的问题是,并非所有硬件都可以很好地支持虚拟化。较老的X86处理器根据执行范围对特定指令会产生不同结果。这就产生了一个问题,因为系统管理程序应该只能在一个最受保护的范围中执行。由于这个原因,诸如VMWare之类的虚拟化解决方案会提前扫描要执行的代码,从而将这些指令替换为一些陷阱指令(trapinstruction),这样系统管理程序就可以正确地处理它们。Xen可以支持一种协作的虚拟化方法,它不需要任何修改,因为客户机知道自己正在进

6、行虚拟化,并已经进行了修改。KVM会简单地忽略这个问题,如果您希望进行虚拟化,就强制必须在更新的硬件上运行。刚开始会觉得这有些不方便,但是考虑到目前上市的较新机器都可以支持虚拟化(例如IntelVT和AMDSVM),用不了多久,这将成为标准方法而不是少数例外情况。KVM系统管理程序考虑到虚拟化技术的发展时间并不长,KVM实际上还是一种相对来说比较新的技术。目前存在各具功能的开源技术,例如Xen、Bochs、UML、Linux-VServer和coLinux,但是KVM目前正在被大量使用。另外,KVM不再仅仅是一个全虚拟化解决方案,而将成为更大的解决方案的一部分。KVM所使用的方法是通过简单地加

7、载内核模块而将Linux内核转换为一个系统管理程序。这个内核模块导出了一个名为/dev/kvm的设备,它可以启用内核的客户模式(除了传统的内核模式和用户模式)。有了/dev/kvm设备,VM使自己的地址空间独立于内核或运行着的任何其他VM的地址空间。设备树(/dev)中的设备对于所有用户空间进程来说都是通用的。但是每个打开/dev/kvm的进程看到的是不同的映射(为了支持VM间的隔离)。KVM然后会简单地将Linux内核转换成一个系统管理程序(在安装kvm内核模块时)。由于标准Linux内核就是一个系统管理程序,因此它会从对标准内核的修改中获益良多(内存支持、调度程序等)。对这些Linux组件

8、进行优化(例如2.6版本内核中的新0(1)调度程序)都可以让系统管理程序(主机操作系统)和Linux客户操作系统同时受益。但是KVM并不是第一个这样做的程序。UML很久以前就将Linux内核转换成一个系统管理程序了。使用内核作为一个系统管理程序,您就可以启动其他操作系统,例如另一个Linux内核或Windows系统。KVM安装KVM之后,您可以在用户空间启动客户操作系统。每个客户操作系统都是主机操作系统(或系统管理程序)的一个单个进程。图2提供了一个使用KVM进行虚拟化的视图。底部是能够进行虚拟化的硬件平台(目前指的是IntelVT或AMD-SVM处理器)。在裸硬件上运行的是系统管理程序(带有

9、KVM模块的Linux内核)。这个系统管理程序与可以运行其他应用程序的普通Linux内核类似。但是这个内核也可以支持通过kvm工具加载的客户操作系统。最后,客户操作系统可以支持主机操作系统所支持的相同应用程序。SingleLtuxPrecis?Gu&stOS(Virtualm豁皿開User-space(appiicscn?)User-space(.appiicarticns)HypsrvsQr(Virtualmachinemonilor)Hardware图2.使用KVM的虚拟化组件记住KVM只是虚拟化解决方案的一部分。处理器直接提供了虚拟化支持(可以为多个操作系统虚拟化处理器)。内存可以通过k

10、vm进行虚拟化(这在下一节中将会讨论)。最后,I/O通过一个稍加修改的QEMU进程(执行每个客户操作系统进程的一个拷贝)进行虚拟化。KVM向Linux中引入了一种除现有的内核和用户模式之外的新进程模式。这种新模式就称为客户模式,顾名思义,它用来执行客户操作系统代码(至少是一部分代码)。回想一下内核模式表示代码执行的特权模式,而用户模式则表示非特权模式(用于那些运行在内核之外的程序)。根据运行内容和目的,执行模式可以针对不同的目的进行定义。客户模式的存在就是为了执行客户操作系统代码,但是只针对那些非I/O的代码。在客户模式中有两种标准模式,因此客户操作系统在客户模式中运行可以支持标准的内核,而在

11、用户模式下运行则支持自己的内核和用户空间应用程序。客户操作系统的用户模式可以用来执行I/O操作,这是单独进行管理的。在客户操作系统上执行I/O的功能是由QEMU提供的。QEMU是一个平台虚拟化解决方案,允许对一个完整的PC环境进行虚拟化(包括磁盘、图形适配器和网络设备)。客户操作系统所生成的任何I/O请求都会被中途截获,并重新发送到QEMU进程模拟的用户模式中。KVM通过/dev/kvm设备提供了内存虚拟化。每个客户操作系统都有自己的地址空间,并且是在实例化客户操作系统时映射的。映射给客户操作系统的物理内存实际上是映射给这个进程的虚拟内存。为了支持客户物理地址到主机物理地址的转换,系统维护了一

12、组影子页表(shadowpagetable)。处理器也可以通过在访问未经映射的内存位置时使用系统管理程序(主机内核)来支持内存转换进程。实例化新客户操作系统新客户操作系统的实例化是由一个名为kvm的工具提供的。这个工具可以与kvm模块协同工作,使用/dev/kvm来加载客户操作系统,将它与虚拟磁盘(主机操作系统中的一个普通文件)关联起来,然后启动客户操作系统。通过一组在/dev/kvm设备上执行的ioctls可以提供控制支持。当第一次打开这个特殊文件时,就会创建一个新的VM对象,它与一个虚拟CPU关联在一起。您然后可以使用几个ioctls来创建一个虚拟CPU,检查kvm版本,创建内存区域,然后

13、启动一个虚拟CPU。您可以使用kvm命令实现这种功能。在接下来的几节中,我们将介绍kvm命令,并给出几个受支持的ioctls的示例。使用KVM如果硬件支持的话,使用KVM实际上非常简单。您需要一个具有虚拟化支持的处理器。通过查看/proc/cpuinfo可以知道系统是否支持虚拟化。这个文件指定了是否支持vmx(Intel)或svm(AMD)扩展。接下来,您需要一个启用了KVM支持的Linux内核。您可以在DeviceDriversVirtualization下的内核配置中完成这种配置。还必须启用处理器对环境的支持。另外,还必须具有kvm和qemu用户空间应用程序。有了启用了虚拟化支持的引导内核

14、,接下来的一个步骤是为客户操作系统创建一个磁盘映像。您可以使用qeumu-img来完成此操作,如下所示。注意这个映像的大小是4GB,但是使用QEMU的写时复制格式(copy-on-write,qcow)时,整个文件将根据需要增长,而不是完全占据这4GB的空间。$qemu-imgcreate-fqcowvm-disk.img4G复制代码在创建虚拟磁盘之后,就可以将客户操作系统加载到其上。下面的例子假设客户操作系统是在CD-ROM上。除了使用CD-ROMISO映像来填充虚拟磁盘之外,还必须在结束时启动这个映像。$kvm-no-acpi-m384-cdromguestos.iso-hdavm-dis

15、k.img-bootd复制代码AriKivity已经编写了一组测试工具来测试KVM,而不需要全部的设备模型。下面的代码片断(来自于kvm-12/user/main.c)从较高的层次上查看了VM的启动(请参见清单1)。控制特性是由内核中的ioctls提供的(具体来说,在./linux-2.6.20/drivers/kvm/kvm_main.c文件中)。对kvm_init的调用会打开/dev/kvm设备,检查版本号(由KVM内核模块导出),然后分配一个KVM上下文对象并填充一些回调函数kvm_create函数会建立并映射两个内存区域,然后使用ioctl(KVM_CREATE_VCPU)创建一个虚拟

16、CPU(VCPU)。load_file函数然后会将映像加载到给定的VM的地址空间中,然后调用kvm_run执行该VM(使用ioctlKVM_RUN)。尽管这个过程非常简单,但是它解释了如何使用KVM实例化新客户操作系统。清单1.测试KVM系统管理程序的应用程序片断intmain()void*vm_mem;kvm=kvm_init(&test_callbacks,0);if(!kvm)fprintf(stderr,kvm_initfailedn);return1;if(kvm_create(kvm,128*1024*1024,&vm_mem)0)kvm_finalize(kvm);fprintf(stderr,kvm_createfailedn);return1;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号