目录

Virtio:针对Linux的I/O的虚拟化框架

Vhost

Vhost-user

Vhost-user与vhost的区别

相关阅读


Virtio:针对Linux的I/O的虚拟化框架


Linux内核支持多种虚拟化模式,并且支持的数量随着虚拟化的进步和新模式的出现(例如 lguest)而增加。但是,让这些虚拟化模式能够在 Linux 之上运行之后,又如何让它们能够在 I/O 虚拟化方面利用底层内核呢?

答案是使用virtio,它为 hypervisor 和一组通用的I/O虚拟化驱动程序提供高效的抽象。探索virtio并了解为什么 Linux将成为最佳的 hypervisor。

完全虚拟化中,guest OS运行于物理机器上的hypevisor上,guest  OS并不知道它已被虚拟化,并且不需要任何更改就可以在该配置下工作。半虚拟化中,guest OS不仅知道它运行在hypervisor之上,还包含让guest OS更高效地过渡到hypervisor的代码。

在完全虚拟化模式中,hypervisor必须模拟设备硬件,它是在会话的最低级别进行模拟的。尽管在该抽象中模拟很干净,但它同时也是最低效、最复杂的。在半虚拟化的模式中,guest OS和hypervisor能够共同合作,让模拟更加高效。

在虚拟机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的模拟网卡是一个非常不错的选择。

但是,e1000网卡上也包含了复杂的io端口,寄存器,缓存配置,虚拟机每次收发包都会引起更多的io和mmio操作,使得虚拟机频繁的陷出,最终导致网络性能不佳。

为了解决性能问题,IBM在2005年提出了virtio(PV Driver (事实上的标准)),虚拟机中的半虚拟化前端驱动和主机上的后端服务简单的使用virtqueue共享队列交换数据,大幅的减少了e1000模拟时复杂的io操作,从而可以较大程度的提升虚拟网络性能。

作为对比,从下面简单的iperf测试中,我们就能看出两者的性能差距:

Vhost


vhost技术对virtio-net进行了优化,在内核中加入了vhost-net.ko模块,使得对网络数据可以再内核态得到处理。

virtio的io路径

  1. guest设置好tx;
  2. kick host;
  3. guest陷出到kvm;
  4. kvm从内核切换到用户态的qemu进程;
  5. qemu将tx数据投递到tap设备;

vhost的io路径

  1. guest设置好tx;
  2. kick host;
  3. guest陷出到kvm;
  4. vhost-net将tx数据投递到tap设备;

vhost将部分virio驱动的操作从用户态移到内核态,减少了用户态/内核态切换时间和包的拷贝次数,从而更进一步的提升了性能,下面的网络延时测试可以看出vhost的优势:

Vhost-user


随着技术的发展,将网络数据放入用户态处理将可以得到更灵活的形式。在原有的vhost架构中,进行了改动,增加了 一种新的vhost-backend,叫做vhost-user。

vhost的io路径

  1. guest设置好tx;
  2. kick host;
  3. guest陷出到kvm;
  4. vhost-net将tx数据投递到tap设备;

vhost-user的io路径

  1. guest设置好tx;
  2. kick host;
  3. guest陷出到kvm;
  4. kvm将通知snabb;
  5. snabb将tx数据直接发送到nic设备。

vhost-user的提交者是Luke Gorrie,他也是snabbswitch的作者。从图上可以看到vhost-backend从原来咋kernel中的vhost-net 变成了用户空间的snabbswitch。 snabbswitch直接接管物理网卡的驱动,从而直接控制网络信息的输入输出。

snabbswitch主要使用了下面的技术来提高性能

  1. 采用了大页来作为host和vm之间通信的内存空间
  2. 用户态操作网卡,使用类似于netmap的zero copy技术来加速对物理设备的访问
  3. 使用numa技术,加快中断响应速率

值得一提的是使用snabbswitch后,不用再使用原来的tap设备模拟的网卡。

使用vhost-user技术,从虚拟机到host上实现了数据的zero copy(通过大页共享),host到nic的zero copy(snabbswitch实现的驱动),能进一步加快数据的传输。

Vhost-user与vhost的区别


Vhost是client与kernel(server)的交互,client与内核共享内存,局限性是如果client要发送消息到用户进程,很不方便;

Vhost-user使用unix domain来进行通信,两个用户进程共享内存,达到和vhost一样的效果。

相关阅读


《Linux虚拟化KVM-Qemu分析(八)之virtio初探》

《Linux虚拟化KVM-Qemu分析(九)之virtio设备》

《virtio 网络的演化》

《使用DPDK打开Open vSwitch(OvS) *概述》

《Open vSwitch(OVS)文档》

《《深入浅出DPDK》读书笔记(十五):DPDK应用篇(Open vSwitch(OVS)中的DPDK性能加速)》

《virtio 网络的演化:原始virtio > vhost-net(内核态) > vhost-user(DPDK) > vDPA》

《Virtio原理简介》

《Virtio、Vhost、Vhost-user介绍》

站外参考文章


《SR-IOV:网卡直通技术》

《关于英特尔® 以太网服务器适配器中 SR-IOV 的常见问题解答》

《Vhost-user详解》

Virtio、Vhost、Vhost-user介绍相关推荐

  1. KVM中virtio、vhost 和vhost-user比较(十一)

    virtio 在虚拟机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的模拟网卡是非常一个不错的选择. 但是,e ...

  2. virtio、vhost和vhost-user比较

    1. virtio:针对Linux的I/O的虚拟化框架 在虚机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的 ...

  3. 2021年二月下旬文章导读与开源项目仓库 | scatter-gather DMA,SR-IOV,ARP欺骗,中断,Lockdep,virtio,vhost

    目录 文章目录 开源项目仓库 [转]浅谈scatter-gather DMA SR-IOV:网卡直通技术 [黑客入门] 连接公共WIFI有多危险(ARP欺骗) DPDK ACL算法介绍 文章目录 Li ...

  4. 高通Q+A Virtio hypervisor touch框架介绍(share-device)

    背景 大家都知道现在高通芯片在汽车行业的座舱域运用比较热门,但是这种现象不是突然冒出来的,高通最早在2015年左右就开始推广他们的第一代座舱芯片820A.而在2018年左右开始推广他们的第二代产品(6 ...

  5. 数据平面开发套件(DPDK)中的Vhost / Virtio的配置和性能

    目录 Vhost / Virtio简介 接收和发送路径 可合并路径 向量路径 不可合并的路径 PVP路径性能比较 I / O转发吞吐量 Mac转发吞吐量 PVP MAC转发吞吐量 测试台信息 关于作者 ...

  6. 异步模式下的 Vhost Packed Ring 设计介绍

    引言 随着计算机硬件资源整合的发展,虚拟化的研究与应用日新月异.Virtio/Vhost作为一种设备虚拟化的典型应用,在业界受到了广泛的关注.Virtio 最开始由Rusty Russell在其200 ...

  7. VIRTIO VHOST

    背景 在虚拟化领域,virtio 随处可见.当前,virtio 可以加速 IO.network子系统. 在 IO 子系统,主要有 virtio-blk, virtio-scsi.同时,有 vhost ...

  8. virtio,vhost 和vhost-user

    virtio 在虚拟机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的模拟网卡是非常一个不错的选择. 但是,e ...

  9. l298n电机驱动模块使用方法_SPDK virtio 驱动模块介绍及使用

    作者简介闫亮 Intel高级软件工程师专注于开源存储SPDK的测试和优化 简介 CONTENTS SPDK  virtio模块介绍 SPDK  virtio 用户模式使用示例 SPDK  virtio ...

最新文章

  1. CentOS5.4下安装短信猫
  2. NUXT: 视图和模板
  3. 折叠屏来了,开发者们准备好了吗?
  4. Extension project: 404 Not Found for resources/cus/crm/notes/ext/Component-dbg.js
  5. 【编译原理】CFG分析树
  6. 【CSS3】填色表格演示hsl()
  7. Nginx的client_header_buffer_size和large_client_header_buffers学习
  8. margin background_div盒子的外部距离(margin)【202】。
  9. 中职学校计算机基础的重要性,中职非计算机专业学生计算机基础教学浅探
  10. 基于全志a31s的camrea驱动调试(gc2145型号)
  11. 网站备案其实是服务器备案,网站备案指的是备案域名还是备案主机空间
  12. VSCode沙绿色主题设置
  13. 怎样将excel表格合并
  14. Licecap for Mac使用教程
  15. phpstorm License Server激活 官网下载版本直接激活
  16. 微信推出“微信圈子”,玩起来原来这么爽?
  17. 李沐动手学深度学习V2-机器翻译和数据集
  18. 26 27 28 副词
  19. 错误: 无法初始化主类
  20. 京东Java岗:来自面试官的夺命连环56问,直接当场怀疑人生~

热门文章

  1. 数学建模-6.典型相关分析
  2. 倩女幽魂2首曝 揭秘网易新3D引擎光影特效
  3. ChatGPT 的安全风险,我们应该信任它吗?
  4. 【机器学习|数学基础】Mathematics for Machine Learning系列之线性代数(11):向量组的线性相关性
  5. 清明看池建强知识星球有感
  6. Common Lisp 超规范(译文):8.结构体
  7. Forbidden Forest 错落森林
  8. 真实案例,大学生接单被骗,希望大家不要被骗了【惨痛教训】
  9. SURF 特征点检测
  10. ubuntu16.04安装搜狗拼音打办法以及相关问题处理