kvm虚拟化原理_kvm 虚拟内存 与任何其他linux 进程的内存一样进行存储-程序员宅基地

技术标签: linux kernel  

名词描述

如果把操作系统共及其提供的系统调用作为资源,那么虚拟化就表现为操作系统虚拟化。linux容器虚拟化就是一个操作系统上,虚拟化出了多个同样的操作系统。
如果把物理平台,包括CPU,内存,外设作为资源,那么对应的虚拟化技术就是平台虚拟化。

VMM(virtual machine monitor) 虚拟机监视器,也叫hypervisor。虚拟机监视器运行的环境叫做host,而虚拟出来的虚拟机成为guest

虚拟化重要一步,就是截取计算元件对物理资源的访问,并重定向到虚拟化资源池中。如果是使用纯软件的方式实现这种截取,那么就称为软件虚拟化,如果是通过硬件方式实现,那么就称为硬件虚拟化。

我的理解

qemu+kqemu就是纯软件的虚拟化,

而qemu+kvm是利用的硬件虚拟化的技术。

利用硬件虚拟化的好处,无需进行二进制转换,减少性能开销,极大简化了VMM的设计,性能更强大。

完整的情况下需要CPU、主板芯片组、BIOS和软件的支持。即使在只有CPU支持的情况下,性能也会比不支持情况好。

intel virtualizaton Technology(IntelVT)

半虚拟化,为了解决纯软件虚拟化下,性能的问题,改动guest操作系统,使他可以自己运行在虚拟环境下。本质上,弱化了对虚拟机特殊指令的被动截取要求,将其转化为guest操作系统的主动通知。Xen是代表

全虚拟化,不需要对guest操作系统进行任何改动,理论上支持任何可在真是物理平台上运行的操作系统。随着硬件虚拟化的出现,全虚拟化的性能已经超过了半虚拟化。

linux kernel通过加载kvm模块变身成一个hypervisor

KVM是基于虚拟化扩展(intel VT或AMD-V)的X86硬件。是linux完全原生的全虚拟化解决方案。
部分的半虚拟化支持,注意是通过半虚拟网络驱动程序的形式用于linux和windowsguest系统。
每个虚拟CPU显示为一个常规的linux进程。
KVM本身不执行任何模拟,需要用户空间程序通过/dev/kvm借口设置一个guest虚拟服务器的地址空间,向他提供模拟的IO,并将它的视频显示映射回数组的显示屏,目前这个应用程序就是QEMU。

KVM原理

架构

在这里插入图片描述

内存管理

一个虚拟机的内存与任何其他linux进程的内存一样进行存储,可以以大页面的形式进行交换以实现更高的性能,也可以以磁盘文件的形式共享。NUMA(非一致性内存访问,针对多处理器的内存设计)支持允许虚拟机有效的访问大量内存。

KVM支持最新的基于硬件的内存虚拟化功能,支持Intel的扩展页表(EPT)和AMD的嵌套页表(NPT,也交快速虚拟化索引-RVI),以实现更低的CPU利用率和更高的吞吐量。

内存页面共享通过一种名为内核同页合并(kernel same-page merging,KSM)的内核功能来支持,KSM扫描每个虚拟机的内存如果虚拟拥有相同的内存页面,KSM将这些页面合并到一个虚拟机之间共享的页面,修改时在获得专享副本

存储

KVM能够使用linux支持的任何存储来存储虚拟机镜像。KVM原声磁盘格式为QCOW2,支持快照,允许多级快照,压缩和加密。

设备驱动程序

KVM支持混合虚拟化,其中准虚拟化的驱动程序安装在guest os中,允许虚拟机使用优化的IO借口而不实用模拟的设备,从而为网络和快设备提供高性能的IO。这个准虚拟化驱动程序使用IBM和ReadHat联合linux社区开发的VirtIO标准。它是一个与虚拟机管理程序独立的、构建设备驱动程序的借口,允许为多个虚拟机管理程序使用一组相同的设备驱动程序。(virtIO是安装在guest os中的模块)

性能和可伸缩性

KVM虚拟化性能在很多方面(计算能力和原生带宽)可以达到非虚拟化原生环境的95%以上。RHEL6.x系统一个KVM客户机可以支持160个虚拟CPU和多大2T内存,一个宿主机支持4096个CPU核心和多达64T内存

原理

虚拟化模型

VMM或Hypervisor的主要职能:管理真是的物理硬件平台,并为每个虚拟guest提供对应虚拟硬件平台。
guest任然可以作为自己的VMM,称为嵌套虚拟化。KVM支持嵌套虚拟化。
在这里插入图片描述

KVM架构

两种架构,类型一,系统上电之后首先加载运行虚拟机监控程序,传统的操作系统运行在其创建的虚拟机中,可以视为一个特别为虚拟化而剪裁过的操作系统内核。一般会提供一个具有一定特权的特殊虚拟机。由这个特权虚拟机提供用户日常操作和管理使用的操作系统环境。代表Xen,VMware ESX/ESXi和微软Hyper-V。类型二,上电后仍然运行一般意义上的操作系统,VMM作为特殊的应用程序,视为操作系统功能的扩展。其最大优势在于可以充分利用现有操作系统,不必实现物理资源管理和调度算法。但是会收到诉诸操作系统的一些限制。无法仅仅为了虚拟机优化,而对操作系统做出修改。

在这里插入图片描述

qemu通过/dev/kvm借口设置一个虚拟客户机的地址空间,向他提供墨迹IO设备,并将显示映射回宿主机显示屏。

KVM模块

主要功能,初始化CPU硬件,打开虚拟化模式,然后将虚拟客户机运行在虚拟机模式下,并对虚拟客户机的运行提供一定的支持。
为了软件简洁,KVM仅支持硬件虚拟化。

KVM先初始化内部数据结构
KVM打开CPU控制寄存器CR4中的虚拟化模式开关,通过执行VMXON指令将host操作系统置于虚拟化模式中的根模式
KVM模块创建/dev/kvm并等待用户空间命令。
KVM和qemu通过对/dev/kvm的ioctl系统调用来通信。
针对虚拟处理器的最重要的IOCTL调用就是执行“虚拟处理器”。通过它,用户空间准备好的虚拟机在KVM模块支持下,被置于虚拟化模式中的非根模式下,并开始执行二进制指令。在非根模式下,所有敏感的二进制指令都会被处理器捕获到,处理器在保存现场之后自动切换到根模式,由KVM决定如何进一步处理(要么由KVM模块直接处理,要么反悔用户空间交由用户空间程序处理)。
内存虚拟化,在硬件支持二维地址翻译之前是最复杂的部分。在虚拟机模式下,内存管理单元的页表必须在一次查询的时候完成两次地址转换。除了要将客户机虚拟地址转换为客户机物理地址,还需要再转为host的物理地址。使用影子页表机制。通过硬件支持,二维分页机制。
处理器对设备的访问主要通过IO指令和MMIO,其中IO指令会被处理器直接接货,MMIO会通过配置内存虚拟化来捕获。对性能要求较高的虚拟设备才会由KVM内核模块直接负责,比如虚拟终端控制器和虚拟始终,这样可以大量减少处理器的模式切换开销。

Qemu设备模型

大部分输入输出都交给qemu来负责

qemu虚拟机是一个纯软件的实现,性能底下。qemu的代码中有整套的虚拟机实现,包括处理器虚拟化,内存虚拟化,以及KVM使用到的虚拟设备模拟(网卡,下卡,存储控制器和硬盘等)。

KVM在qemu基础上进行了修改,虚拟机运行期间,qemu会通过KVM模块提供的系统调用进入内核,由KVM模块负责将虚拟机置于处理器的特殊模式运行。遇到虚拟机进行输入输出操作,kvm从上次的系统调用出口处反悔qemu,由qemu来负责解析和模拟这些设备(是不是可以理解为,从创建虚拟机后,就交由kvm负责,运行在特殊模式,直到发生了IO操作,切换到用户态,交由qemu负责)。
从qemu角度来看,使用了KVM模块的虚拟化功能,为自己的虚拟机提供硬件虚拟化的枷锁,极大的提升了虚拟机性能。除此之外,虚拟机的配置和创建,虚拟机运行以来的虚拟设备,虚拟机运行时用户操作环境和交互,以及一些针对虚拟机的特殊技术(诸如动态歉意),都是由qemu自己实现的。

kvm和qemu都可以选择其他虚拟机或技术来枷锁,比如qemu可以选择xen或者kqemu,而kvm也可以选择其他应用程序,只要它按照kvm提供的API来设计。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/oscube/article/details/106740164

智能推荐

c# 调用c++ lib静态库_c#调用lib-程序员宅基地

文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib

deepin/ubuntu安装苹方字体-程序员宅基地

文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang

html表单常见操作汇总_html表单的处理程序有那些-程序员宅基地

文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些

PHP设置谷歌验证器(Google Authenticator)实现操作二步验证_php otp 验证器-程序员宅基地

文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器

【Python】matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距-程序员宅基地

文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距

docker — 容器存储_docker 保存容器-程序员宅基地

文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器

随便推点

网络拓扑结构_网络拓扑csdn-程序员宅基地

文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn

JS重写Date函数,兼容IOS系统_date.prototype 将所有 ios-程序员宅基地

文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios

如何将EXCEL表导入plsql数据库中-程序员宅基地

文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql

Git常用命令速查手册-程序员宅基地

文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...

分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120-程序员宅基地

文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120

【C++缺省函数】 空类默认产生的6个类成员函数_空类默认产生哪些类成员函数-程序员宅基地

文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数

推荐文章

热门文章

相关标签