https://blog.csdn.net/shengxia1999/article/details/52244119

KVM:Kernel-Based Virtual Machine 基于内核的虚拟机,是Linux内核的一个可加载模块,通过调用Linux本身内核功能,实现对CPU的底层虚拟化和内存的虚拟化,使Linux内核成为虚拟化层,需要x86架构的,支持虚拟化功能的硬件支持(比如Intel VT,AMD-V),是一种全虚拟化架构。KVM在2007年年2月被导入Linux 2.6.20内核中。从存在形式来看,它包括两个内核模块:kvm.ko  和  kvm_intel.ko(或kvm_amd.ko),本质上,KVM是管理虚拟硬件设备的驱动,该驱动使用字符设备/dev/kvm(由KVM本身创建)作为管理接口,主要负责vCPU的创建,虚拟内存的分配,vCPU寄存器的读写以及vCPU的运行。

QEMU:是一套由Fabrice Bellard编写的模拟处理器的自由软件,它是一个完整的可以单独运行的软件,可以独立模拟出整台计算机,包括CPU,内存,IO设备,通过一个特殊的“重编译器”对特定的处理器的二进制代码进行翻译,从而具有了跨平台的通用性。QEMU有两种工作模式:系统模式,可以模拟出整个电脑系统,另一种是用户模式,可以运行不同与当前硬件平台的其他平台上的程序(比如在x86平台上运行跑在ARM平台上的程序)

在QEMU-KVM中,KVM运行在内核空间,QEMU运行在用户空间,实际模拟创建,管理各种虚拟硬件,QEMU将KVM整合了进来,通过/ioctl 调用 /dev/kvm,从而将CPU指令的部分交给内核模块来做,KVM实现了CPU和内存的虚拟化,但kvm不能虚拟其他硬件设备,因此qemu还有模拟IO设备(磁盘,网卡,显卡等)的作用,KVM加上QEMU后就是完整意义上的服务器虚拟化。

当然,由于qemu模拟io设备效率不高的原因,现在常常采用半虚拟化的virtio方式来虚拟IO设备。

综上所述,QEMU-KVM具有两大作用:

1.提供对cpu,内存(KVM负责),IO设备(QEMU负责)的虚拟

2.对各种虚拟设备的创建,调用进行管理(QEMU负责)

libvirt

顺带提一提libvirt,这是RedHat开始支持KVM后,大概是觉得QEMU+KVM方案中的用户空间虚拟机管理工具不太好用或者通用性不强,所以干脆搞了个libvirt出来,一个针对各种虚拟化平台的虚拟机管理的API库,一些常用的虚拟机管理工具如virsh(类似vim编辑器),virt-install,virt-manager等和云计算框架平台(如OpenStack,OpenNebula,Eucalyptus等)都在底层使用libvirt提供的应用程序接口。

libvirt主要由三个部分组成:API库,一个守护进程 libvirtd 和一个默认命令行管理工具 virsh。

总结:

目前来说,QEMU是一个独立的虚拟化解决方案,并不依赖KVM(它本身自己可以做CPU和内存的模拟,只不过效率较低),而KVM是另一套虚拟化解决方案,对CPU进行虚拟效率较高(采用了硬件辅助虚拟化),但本身不提供其他设备的虚拟化,借用了QEMU的代码进行了定制,所以KVM方案一定要依赖QEMU。

即使后来RedHat后来开发了libvirt,也只能简单的认为是个虚拟机管理工具,仍然需要通过用户空间QEMU来与KVM进行交互。

http://lihanlu.cn/virtio-introduction/

实现IO虚拟化主要有三种方式:全虚拟化、半虚拟化和透传。全虚拟化Guest OS不会感知到自己是虚拟机,也无需修改Guest OS,但是它的效率比较低。半虚拟化Guest OS知道自己是虚拟机,通过Frontend/Backend驱动模拟实现IO虚拟化。透传就是直接分配物理设备给VM用。Virtio是一种半虚拟化的设备抽象接口规范,在Qemu和KVM中得到了广泛使用,本文将简单介绍Virtio的基本原理。

Virtio SPEC

* Virtual I/O Device (VIRTIO) Version 1.0

* http://docs.oasis-open.org/virtio/virtio/v1.0/cs04/virtio-v1.0-cs04.html

* Virtio PCI Card Specification Version 0.9.5

* http://ozlabs.org/~rusty/virtio-spec/virtio-0.9.5.pdf

每个Virtio设备包括以下部分

* Device status field  设备状态字段

* Feature bits  特征位

* Device Configuration space  设备配置空间

* One or more virtqueues  一个或多个virtqueues

每个virtqueue由三部分组成:

* Descriptor Table

* Available Ring

* Used Ring

如图所示,virtnet_info作为virtio网络设备的私有数据将virtio_device和net_device链接在一起。对于virtio网络设备来说,它至少有两个virtqueue(如果协商了VIRTIO_NET_F_MQ则可以创建多个队列,详见VirtIO SPEC中5.1.2 ),一个用于TX(send_queue),另一个用于RX(receive_queue),TX和RX队列中都包含了virtqueue和scatterlist[]。virtio_device、virtnet_info、receive_queue、send_queue、virtqueue给定任一结构体均可得到其它结构体信息。

可以把virtqueue理解为一个接口类,而vring_virtqueue作为这个接口的一个实现,vring_virtqueue通过成员vq可以与上述其它struct建立联系。virtio的环形缓冲区机制是由vring来承载的,vring由三部分组成:Descriptor表(vring_desc),Available ring(vring_avail)和Used ring(vring_used)。

https://www.jianshu.com/p/9be4969e0bb1

virtio作为一种设备,同样也处在Linux kernel对设备模型的管理之下,virtio使用了virtio pcibus类型的虚拟总线,当命令行传入virtio时,Qemu会根据注册的virtio_net_pci_info进行virtio net设备的初始化,并在Qemu自身模拟的pci bus层加入了virtio net设备的初始化信息。

当Qemu加载Guest OS后,Guest OS的Bios和Kernel的启动过程中会对Pci设备进行枚举和资源的分配。

当总线类型注册后,/sys/bus/目录下,创建了一个新的目录virtio,在该目录下同时创建了两个文件夹为devices和drivers。表示创建virtio总线,总线支持设备与驱动devices和drivers目录。

计算机io工作方式,QEMU/KVM和VirtIO工作模式相关推荐

  1. tiri单片机_51单片机设定串口的工作方式:设定SCON寄存器-控制器/处理器-与非网...

    用计算机来控制单片机,进而控制继电器等其他外设,感觉不错啊,怎么实现呢?一步步来吧. 单片机串行口通信,也就是单片机与计算机之间的通信,要实现,要明白一些基本的概念. (1)实现之前,请确定串口正常, ...

  2. “工时通”助力新工作方式

    概述 近10年来日新月异的信息网络技术,为各类组织工作的开展提供了不可或缺的技术平台,也使得员工的远程办公成为了当今组织的一种弹性工作安排方式.由于远程办公能够满足组织和员工的多种需求,越来越多的西方 ...

  3. 个人计算机与PLC的工作方式有什么不同,plc的工作方式

    plc的工作原理和计算机的工作原理基本上一致.但是工作方式有所不同,计算机采用等待命令的工作方式,而PLC采用循环扫描的工作方式. PLC有两种工作方式:运行(RUN)与停止(STOP).处于停止工作 ...

  4. apache php 工作模式,PHP Apache中两种工作方式区别(CGI模式、Apache 模块DLL)

    搜索热词 对PHP在Apache中两种工作方式的区别(CGI模式.Apache 模块DLL)感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧! Windows 下有两种方法使 ...

  5. 8255A的工作方式控制字

    北京交通大学戴胜华老师MOOC微机原理与接口技术 8255A的工作方式控制字,设置工作方式0方式1方式2 B口4种方式,方式1有选通信号,方式0是无条件的输入输出方式(程序控制方式)没有选通信号 PC ...

  6. 数据的编码类型及数据通信的工作方式

    文章目录 前言 模拟数据和数字数据都可以用模拟信号或数字信号来表示和传输.在一定条件下,可以将模拟信号编码为数字信号,或将数字信号编码为模拟信号.并且数据通信时的工作方式也有所不同. 一.数据的编码类 ...

  7. 7. 【可编程定时器8253】:外部引脚、内部结构特点、计数启动方式、6种工作方式、控制字格式、应用

    文章目录 计数与定时 8253芯片特点 1. 外部引脚 2. 内部结构特点(含3个计数器.1个控制寄存器) 2. 计数启动方式(软件启动.硬件启动的定义) 3. 6种工作方式 不能自动重复计数的工作方 ...

  8. pLC支持C语言编程执行复杂控制,能够实现多种工作方式的plc控制系统的编程

    原标题:能够实现多种工作方式的plc控制系统的编程 今天给大家带来的文章是:能够实现多种工作方式的plc控制系统的编程,这篇文章带我们一起揭晓实现多种工作方式的PLC编程控制系统是怎么做的. 自动控制 ...

  9. 商务手机最大突破是打破墨守成规的工作方式

    商务手机最大突破是打破墨守成规的工作方式 文/王易见 在我对刚买的一台超便携上网本赞不绝口之际,朋友推荐给我的一款商务手机发了我更大的兴趣.所谓"世界因懒人而改变",如果不是我们越 ...

最新文章

  1. 构造方法,this,super关键字
  2. 达内TTS6.0课件oop_day01
  3. torch.Tensor和torch.tensor有什么区别?
  4. apache camel file(二)
  5. 【感悟】参加公司首届黑客马拉松有感
  6. 初探Spring Cloud-Netflix
  7. 判断体型c语言程序,C语言程序设计经典体型.doc
  8. [激光原理与应用-26]:《激光原理与技术》-12- 激光产生技术-短脉冲、超短脉冲、调Q技术、锁模技术
  9. 一款实用的web截图工具(一)
  10. 刷题——Python篇(2)类型转换
  11. css中a标签超链接在新窗口中打开以及超链接去除/添加下划线
  12. java中流_Java中流的有关知识点详解
  13. DDoS 攻击与防护(一):如何识别 DDoS 攻击?DDoS 防护 ADS 服务有哪些?
  14. EasyUI树形菜单后端
  15. dnf服务器炸团门票怎么找回,DNF:还在为魔界裂缝门票发愁吗?这些地方可以轻松获取门票...
  16. java基于安卓Android/微信小程序的高校校园跑腿系统 uniapp
  17. Navicat导出excel数据量过大解决方案
  18. opencv - 简介
  19. 计算机自然语言处理专业排名,请大牛们推荐一些计算机专业自然语言处理或人工智能方面比较好的EI期刊 - 论文投稿 - 小木虫 - 学术 科研 互动社区...
  20. Apache batik 转换svg文件为jpeg/png/pdf

热门文章

  1. python shelve模块_python常用模块之shelve模块
  2. keras concatenate_Keras结合Keras后端搭建个性化神经网络模型
  3. iphone降级_无刘海 iPhone 现身苹果官网iOS 13.3 系统验证已关闭
  4. 传感器信号 如何发送到服务器,传感器如何将消息发送给云服务器
  5. linux的安装nmom命令,Linux下块设备查看命令lsblk详解
  6. 寄存器、cache、内存、硬盘之间的千丝万缕
  7. LCD液晶屏静电防护方案
  8. linux系统清除日志,如何清除Linux系统日志
  9. python函数映射教学,Python 序列与映射的解包操作
  10. oracle定时器定时删除30天前的数据_Redis的过期键删除策略