设为首页 收藏本站
查看: 1289|回复: 0

[经验分享] KVM基本原理和架构二-基本原理

[复制链接]

尚未签到

发表于 2015-12-24 15:38:14 | 显示全部楼层 |阅读模式
2 KVM基本原理 2.1 KVM架构
KVMKernel-based Virtual Machine,是基于Linux内核的开源虚拟化解决方案,从2.6.20版本开始被合入kernel主分支维护。最初只支持X86平台的上支持VMX或者SVMCPU,不久后被确认为标准Linux内核的虚拟化方案并逐步支持S390IA64PowerPC等体系架构;KVM本身只提供部分的虚拟化功能(虚拟CPU和内存),而由经过特殊改造后的Qemu(Qemu-kvm)来帮助下提供完整的平台虚拟化功能。
KVM依赖于x86硬件的虚拟化特性,提供全虚拟化的虚拟机,其基本思想是在Linux内核的基础上添加虚拟机管理模块,重用Linux内核中已完善和成熟的机制和模块,比如进程调度、内存管理、IO管理等,使之成为一个可以支持运行虚拟机的Hypervisor。整体架构如下图所示:





      
        KVM是基于硬件辅助虚拟化技术(Intel VT-x)的全虚拟化解决方案,如上图所示,说明如下:
ü  VMM(KVM内核)运行于根模式下的Ring0
ü  主机上的用户态进程运行于根模式下的Ring3
ü  虚拟机中的Kernel运行于非根模式下的Ring0
ü  虚拟机中的用户态进程运行于非根模式下的Ring3
ü  Qemu-kvmKVM官方提供并维护的改进后的Qemu,针对KVM解决方案,将标准Qemu做了针对性的改造,使其具有更好的性能,并与KVM进行了完美的融合;
ü  一个VM(虚拟机)就是一个传统的Linux进程,VM运行于Qemu-KVM进程的地址空间中;
ü  VMM向上层提供/dev/kvm接口,/dev/kvm是一个标准的字符设备,通过ioctl接口控制;Qemu-kvm通过调用/dev/kvm设备的ioctl接口,对虚拟机进行相关控制,比如创建虚拟机、创建VCPU、运行虚拟机等;
ü  为提升KVM虚拟机中的IO性能,KVM还提供了Virtio驱动,相当于Xen环境中的半虚拟化驱动。
2.2 KVM运行视图
KVM运行的基本如下图所示:
http://blog.iyunv.com/attachment/201403/5/14528823_1393999823FbkG.bmp



    流程描述:

1、    运行在用户态的Qemu-kvm通过ioctl系统调用操作/dev/kvm字符设备,创建VMVCPU
2、    内核KVM模块负责相关数据结构的创建即初始化,然后返回用户态
3、    Qemu-kvm通过ioctl调用运行VCPU,即调度相应的VM运行
4、    内核进行相关处理后,执行VMLAUNCH指令,通过VM-Entry进入Guest OS运行,Guest OS运行于非根模式下。
5、    Guest OS执行相应的虚拟机代码,非敏感指令可直接在物理CPU上运行
6、    Guest OS中执行到敏感指令、发生外部中断、或Guest OS发生内部异常时,将产生VM-Exit,并将相关信息记录到VMCS结构中
7、    VM-Exit使CPU退回到根模式下,由VMM读取VMCS结构判断VM-Exit的原因
8、    如是IO操作或是其他外设指令,则返回到用户态Qemu-kvm(即根模式下的Ring3),由Qemu-kvm完成对相关指令的模拟。
9、    如果不是,则由VMM自行处理
10、处理完成后,重新VM-entry进入到Guest OS运行。
2.3 KVM内核模块组成
KVM主要由3个内核模块组成:
ü  Kvm.ko
ü  Kvm-intel.ko
ü  Kvm-amd.ko
Kvm.koKVM的核心公共模块,kvm-intel.kokvm-amd.ko分别是针对IntelAMD平台架构的独立模块。在KVM核心公共模块中,包含了IOMMU、中断控制、KVM arch、设备管理等部分代码,这些代码构成了虚拟机管理的核心功能,从这些模块的大致信息,也可以看出KVM自身并没有实现一个完整的PC系统的虚拟化,而只是实现了最核心的CPU虚拟化、内存虚拟化和IO虚拟化等部分功能并向上层提供了相应的API,其余虚拟化和管理工作主要交给了Qemu-kvm负责。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-155845-1-1.html 上篇帖子: KVM基本原理及架构五-IO虚拟化 下篇帖子: KVM基本原理和架构一-概念和术语
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表