作家
登录

说一说虚拟化绕不开的IO半虚拟化

作者: 来源: 2018-01-17 17:31:27 阅读 我要评论

IO全虚拟化应用QEMU软件模仿

年前最后一场技巧盛宴 | 1月27日与京东、日记易技巧大年夜咖畅聊智能化运维成长趋势!


下面这张图(来自收集)是软件模仿IO的流程图:

QEMU-KVM作为一个VMM供给了全虚拟化情况,guest不经由任何修改就能运行在KVM情况中。不过KVM在IO虚拟化方面,应用QEMU纯软件的方法来模仿IO设备,效力并不高。在KVM中,要想进步IO虚拟化的效力,就要应用半虚拟化的方法:virtio。

简单介绍全虚拟化和半虚拟化

在全虚拟化 中,guest操作体系运行在VMM之上,并不知道它已被虚拟化,不须要任何更改就可以工作。相反,在半虚拟化中,guest操作体系不仅知道它运行在 VMM上,还须要做修改来对接VMM的代码。

在全虚拟化中,VMM必须模仿设备硬件,尽管这种模仿很彻底很干净,但它效力低代码最复杂。在半虚拟化模式中,guest和 VMM合营合作,模仿加倍高效。

1.当虚拟机进行I/O操作时,根据《也谈Intel的cpu虚拟化》我们知道,虚拟机经由过程VM exit将cpu控制权返回给VMM,大年夜而陷入到root模式下的ring0内的VMM,进行”陷入模仿“。

2.将本次I/O请求的信息存放到IO共享页,QEMU大年夜IO共享页攫守信息后由硬件模仿代率攀来模仿出本次的IO操作,并调用内核中的硬件驱动把IO请求发送到物理硬件,完成之后将结不雅放回到IO共享页。

3.KVM模块中的捕获代码攫取IO共享页中的结不雅,把结不雅返回到guest。

4.经由过程VM entry,guest再次获得cpu控制权,根据IO返回的结不雅进行处理。

解释:VMM和guest的IO信息共享不但IO共享页一种,还可以应用DMA。QEMU不把IO结不雅放到IO共享页中,而是经由过程DMA将结不雅直接写到guest的内存中去,然后经由过程KVM模块告诉客户机DMA操作已经完成。

IO半虚拟化virtio

guest和host应用应用virtio前后端的技巧削减了guest IO时的VM Exit(guest和host的高低文切换)并且使guest和host能并行处理IO来进步throughput和削减latency。然则IO的路径并没有比全虚拟化技巧削减。下面是virtio的IO路径:

guest在IO请求时,起首guest须要切换到host kernel,然后host kernel会切换到hyperisor来处理guest的请求,hypervisor经由过程体系调用将数据包发送到外部收集后切换回host kernel,然后再切换回guest。这个长IO路径和全虚拟化时雷同的,只是削减了VM exit和VM entry。

vhost

为懂得决virio的IO路径太长的问题,vhost产生了。它是位于host kernel的一个模块,用于和guest直接通信,所以数据交换就在guest和host kernel间进行,削减了高低文的切换。vhost相对与virto架构,把virtio驱动后端驱动大年夜用户态放到了内核态中(vhost的内核模块充当virtiO后端驱动)

下面这张图(来自redhat)描述了在virtio和vhost(vhost-net时vhost架构中的网卡实现)架构下内核的不合工作流程:

下面这张图(来自intel)介绍了vhost工作道理:

vhost-user

vhost-user和vhost类似,只是应用一个用户态过程vhost-user代替了内核中的vhost模块。vhost-user过程和Guset之间时经由过程共享内存的方法进行数据操作。vhost-user相对与vhost架构,把virtio驱动后端驱动大年夜内核态又放回到了用户态中(vhost-user过程充当virtiO后端驱动)。

下面这张图(来自intel)介绍了vhost-user的工作道理:

总结

io虚拟化经历了大年夜全虚拟化io到半虚拟化virtio。半虚拟化的后端驱动又经历了大年夜VMM中到内毫闼楝大年夜内核中到用户空间中的过程。

【编辑推荐】

  1. 寻找VMware Workstation衬着器中的马脚
  2. 聊一聊虚拟化基本常识
  3. 虚拟化技巧在移动便携设备中的应用
  4. 桌面虚拟化:集中照样分布?
  5. 容量治理在虚拟化情况中至关重要
【义务编辑:武晓燕 TEL:(010)68476606】

  推荐阅读

  设计和实现一款轻量级的爬虫框架

年前最后一场技巧盛宴 | 1月27日与京东、日记易技巧大年夜咖畅聊智能化运维成长趋势! 说起爬虫,大年夜家可以或许想起 Python 里赫赫有名的 Scrapy 框架, 在本文中我们参考这个设计思惟应>>>详细阅读


本文标题:说一说虚拟化绕不开的IO半虚拟化

地址:http://www.17bianji.com/lsqh/40338.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)