当前位置:首页 > 虚拟机 > 正文

kvm虚拟机是做什么用的


一、虚拟化技术—QEMU-KVM基于内核的虚拟机

探索虚拟化巅峰:QEMU-KVM的基础和高效运行


QEMU-KVM,是与Linux集成的高效虚拟化解决方案,其核心是TYPE1Hypervisor,该方案采用硬件辅助虚拟化技术,与Linux内核紧密配合,以其资源管理和优异的性能而脱颖而出。要了解KVM,首先要知道它是如何利用内核模块等硬件支持来提供虚拟环境的控制和优化,以保证兼容性和效率。


2007年,KVM正式加入Linux家族,支持多核(SMP)和NUMA架构。其功能扩展到LiveMigration和KernelSame-pageMerging(KSM),显着提高了动态性。迁移和内存管理的效率。启动时,KVM内核模块在RootMode下初始化,并通过UserApplicationQEMU像魔术一样模拟虚拟硬件并向虚拟机提供服务。


QEMU,由天才开发者FabriceBellard于2001年推出,名为TYPE2Hypervisor,基于动态二进制翻译技术,兼容多种架构。CPU也模拟设备,尽管其性能较差略低于KVM。虽然较差,但QEMU的多功能性使其可以与KVM结合,创建强大的QEMU-KVM分支。两者共同推动虚拟化技术的创新。


KVM软件组件包括:内核模块、QEMU开源虚拟机管理器、AWS、阿里云等服务提供商云服务中使用的QEMU-KVM以及virtioTogether驱动程序。为虚拟化技术奠定坚实的基础。


虽然QEMU-KVM分支是QEMU的一部分,但在KVM环境中我们更喜欢将QEMU称为KVM执行引擎。KVM的工作原理非常智能。驻留在内核空间,通过/dev/kvm与用户空间实时交互,并提供libkvm库。QEMU通过open、close、ioctl等系统调用访问KVM接口,实现CPU、内存和I/O虚拟化,而VM管理和I/O仿真则由QEMUcreate独立处理。


创建虚拟机的过程就像一门艺术一样精确:首先打开/dev/kvm,通过ioctl命令创建VM,并配置硬件抽象层(HVA)和物理寻址(HPA)以及PCI设备的仿真。然后映射QEMU映像、构建vCPU并启动GuestOS。在此过程中,主线程不断监听VM的退出事件,以响应中断并访问虚拟环境中的设备。


当设备中或设备访问触发退出事件时,KVM接管CPU,Linux内核通过ioctl与QEMU交互,管理虚拟机及其vCPU。KVM支持三种操作模式:User、Kernel(root模式)和Guest(非root模式)。QEMU通过/dev/kvm实现内存虚拟化,并创建全局页表(GPA)映射以确保GuestOS隔离。对于I/O虚拟化,QEMU负责模拟设备和捕获I/O请求,构建QEMU-KVM架构,由vCPU、虚拟内存、I/O虚拟和GuestOS构建,形成单个用户进程结构。


QEMU-KVM的架构经过智能化设计。vCPU根据HostOS的调度由GuestOS和HostOS共同管理,形成两层调度:GuestOS负责高层管理。HostOS(LinuxScheduler)负责底层调度,包括vCPU线程、QEMU线程和物理CPU。KVM支持SMP和NUMA,允许用户自定义虚拟机的vCPU布局,保证迁移过程中CPU型号的安全。


通过-qemu-kvm命令,开发人员可以自定义VM的CPU配置并选择自定义型号和功能。但是,应该注意的是,软件模拟会影响性能。默认使用-host模式,磁盘设备选项丰富多样,包括文件路径、接口类型、索引、格式等。-boot等引导选项用于指定引导设备,并根据体系结构支持不同的字符标识符。QEMU的网卡仿真功能非常强大,支持多种类型的网卡、MAC地址和VLAN。它甚至可以通过Tap接口连接到物理网络,并支持用户模式网络堆栈设计。


QEMU-KVM以其卓越的性能和灵活性引领我们探索更高层次的计算世界,这是虚拟化技术的一次精彩之旅。无论是基本配置还是高级功能,QEMU-KVM以优秀的技术设计为云计算和虚拟化环境提供了强有力的支持。


二、kvm与vmware的区别存在实现方法的差异、性能的差异、安全性的差异、管理的差异、应用的差异。
1.实现方式的差异:KVM是一种基于Linux内核的硬件虚拟化技术。它将Linux内核转换为可用于虚拟化的虚拟机管理程序。VMware是一个独立的第三方管理程序,可以安装在各种操作系统上。
2。性能差异。从性能角度来看,KVM对于高密度工作负载具有明显的优势,因为它直接访问物理硬件。VMware需要一定的虚拟化技能,因此在这方面相对较弱。
3。区别在于安全性。从安全角度来看,KVM是高度安全的,因为它是在Linux内核之上实现的,并且继承了Linux内核的安全机制。VMware是基于操作系统的虚拟化技术,安全性较低,因为VMware运行在操作系统上,因此仅限于操作系统。
4。区别在于管理:Linux可以内置KVM虚拟机管理器来管理虚拟机。如果您熟悉Linux,您会发现使用KVM虚拟机更容易。管理VMware需要专门的管理软件,这对于不熟悉VMware技术的管理员来说可能很困难。
5。应用差异:KVM虚拟机基于Linux内核,因此更适合在Linux系统上运行。VMware更适合在Windows系统上运行。