Qemu是一个独立的虚拟化解决方案,通过inter-VT或AMD SVM实现虚拟化,安装qemu的系统,可以直接 模拟吹另一个完全不同的系统环江,虚拟机的创建通过qemu-image即可完成。Qemu本身可以不依赖KVM,但是如果有KVM的存在并且硬件(处理器)支持比如Inter VT功能,那么QEMU在对处理器虚拟化这一块可与里哦用KVM提供的功能来提升性能。
KVM 是集成到 Linux 内核的 Hypervisor 是 X86 架构且硬件支持虚拟化技术(IntelVT或AMD-V)的Linux 的全虚拟化解决方案。它是Linux 的一个很小的模块,利用 Linux 做大量的事,如任务调度、内存管理与硬件设备交互等。准确来说,KVM 是Linux kernel 的一个模块。可以用命令 modprobe 去加载KVM 模块。加载了模块后,才能进一步通过其他工具创建虚拟机。但仅有KVM 模块是远远不够的,因为用户无法直接控制内核模块去作事情,你还必须有一个运行在用户空间的工具才行。这个用户空间的工具,kvm 开发者选择了已经成型的开源虚拟化软件 QEMU。说起来QEMU 也是一个虚拟化软件。它的特点是可虚拟不同的CPU。比如说在x86 的CPU 上可虚拟一个Power 的CPU,并可利用它编译出可运行在Power 上的程序。KVM 使用了QEMU 的一部分,并稍加改造,就成了可控制 KVM 的用户空间工具了。所以你会看到,官方提供的 KVM 下载有两大部分(qemu 和 kvm)三个文件(KVM 模块、QEMU 工具以及二者的合集)。也就是说,你可以只升级 KVM 模块,也可以只升级QEMU 工具。这就是 KVM 和QEMU 的关系。 KVM 内核模块本身只能提供CPU 和内存的虚拟化,所以它必须结合QEMU 才能构成一个完成的虚拟化技术,这就是下面要说的qemu-kvm。
Qemu 将KVM 整合进来,通过 ioctl 调用/dev/kvm 接口,将有关CPU 指令的部分交由内核模块来做。kvm 负责 cpu 虚拟化+内存虚拟化,实现了 cpu 和内存的虚拟化,但kvm不能模拟其他设备。qemu 模拟 IO 设备(网卡,磁盘等),kvm 加上 qemu 之后就能实现真正意义上服务器虚拟化。因为用到了上面两个东西,所以称之为qemu-kvm。 Qemu 模拟其他的硬件,如 Network, Disk,同样会影响这些设备的性能,于是又产生了pass through 半虚拟化设备virtio_blk, virtio_net,提高设备性能。
Libvirt 是管理虚拟机和其他虚拟化功能,比如存储管理,网络管理的软件集合。它包括一个API 库,一个守护程序(libvirtd)和一个命令行工具(virsh);libvirt 本身构建于一种抽象的概念之上。它为受支持的虚拟机监控程序实现的常用功能提供通用的 API。 libvirt 的主要目标是为各种虚拟化工具提供一套方便、可靠的编程接口,用一种单一的方式管理多种不同的虚拟化提供方式。
KVM 是最底层的 hypervisor,它是用来模拟 CPU 的运行,它缺少了对 network 和周边 I/O 的支持,所以我们是没法直接用它的。QEMU-KVM 就是一个完整的模拟器,它是构建基于KVM 上面的,它提供了完整的网络和 I/O 支持。Openstack 不会直接控制qemu-kvm,它会用一个叫libvirt 的库去间接控制qemu-kvm。libvirt 提供了跨 VM 平台的功能,它可以控制除了 QEMU 之外的模拟器,包括 vmware, virtualbox, xen 等等。所以为了openstack 的跨 VM 性,所以openstack 只会用 libvirt 而不直接用 qemu-kvm。libvirt还提供了一些高级的功能,例如 pool/vol 管理。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。