虚拟化
1.虚拟化介绍
(1)虚拟化模型
(2)通过虚拟化工具把cpu、内存、硬盘等真实硬件资源模拟成更少的虚拟硬件资源
(3)为什么要虚拟化?
使硬件资源使用率最大化、云计算领域
(4)虚拟化分类
1)软件级别:所有硬件通过模拟器模拟出来(qemu)
2)硬件级别:通过VMM(虚拟化监视器)将硬件分配和管理,操作系统运行在建立好的vm上(Xen、vmware[ESX、workstation]、kvm、virtualbox)
3)操作系统级别:虚拟机操作系统和宿主操作系统共享,可以模拟上千个虚拟机出来(openvz)
2.半虚拟化、全虚拟化
(1)半虚拟化(para-virtualization)
半虚拟化宿主机和客户机都需要更改操作系统内核、客户机知道宿主机的存在,两者需要协同合作。(Xen支持半虚拟化)
(2)全虚拟化(full virtualization)
全虚拟化为客户机提供了完整虚拟硬件资源,客户机不需要做任何更改,它不知道宿主机的存在。(kvm属于全虚拟化,vmware也是全虚拟化)
(3)半虚拟化性能要比全虚拟化高
3.Xen和KVM比较
(1)不管cpu支持不支持虚拟化,Xen都可以安装,而KVM必须要cpu支持虚拟化才行。
(2)Xen支持半虚拟化也支持全虚拟化,KVM仅支持全虚拟化
(3)安装Xen后,Xen会替换原来的内核接管系统管理。而KVM仅仅是Linux内核的一个模块,依然由系统原内核管理系统。
(4)KVM是后起之秀,历史没有Xen早,但是KVM出来后得到广大Linux内核喜爱,就是因为KVM不像Xen那样需要修改内核,接管内核。
(5)Xen被Ctrix收购,有商业版的Xen Server,而KVM被RedHat收购。
(6)在Xen的体系结构中,XenHypervisor运行于硬件之上,并且将系统资源进行了虚拟化,将虚拟化的资源分配给上层的虚拟机(VM),然后通过虚拟机VM来运行相应的客户机操作系统。
4.KVM介绍
(1)KVM全称kernel-virtual-machine,是针对包含虚拟化扩展(IntelVT或AMD-V)的x86硬件上的完全原生的虚拟化解决方案。
(2)是以色列Qumranet开发,基于Linux内核。2008年9月4日RedHat公司收购KVM。
(3)rhel5/centos5默认是Xen,rhel6/centos6版本默认是kvm。
5.KVM架构
(1)KVM驱动:作为Linux内核的一个模块,其主要负责虚拟机的创建,虚拟机内存的分配,vcpu寄存器的读写以及vcpu的运行。
(2)Qemu:用于模拟虚拟机的用户空间组件,提供I/O设备模型,访问外设的途径。
(3)Libvirt,virsh:由于QEMU工具效率不高,RedHat为KVM开发了辅助工具,比如libvirt、libguestfs等。Libvirt是一套提供了多种语言接口的API,为各种虚拟化工具提供一套方便、可靠的编程接口,而且支持Xen。使用libvirt,你只需通过libvirt提供的函数连接到KVM或Xen宿主机,便可以用同样的命令控制不通的虚拟机了。Libvirt不仅提供API,还自带一套基于文本的管理虚拟机的命令virsh,可以通过使用virsh命令来使用libvirt的全部功能。
(4)virt-manager是一套用python编写的全虚拟机管理图形界面,用户可以通过它直观地操作不用的虚拟机,利用libvirt的API实现的。
6.安装KVM准备