Virtio、Vhost、Vhost-user介绍
目录
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路径
- guest设置好tx;
- kick host;
- guest陷出到kvm;
- kvm从内核切换到用户态的qemu进程;
- qemu将tx数据投递到tap设备;
vhost的io路径
- guest设置好tx;
- kick host;
- guest陷出到kvm;
- vhost-net将tx数据投递到tap设备;
vhost将部分virio驱动的操作从用户态移到内核态,减少了用户态/内核态切换时间和包的拷贝次数,从而更进一步的提升了性能,下面的网络延时测试可以看出vhost的优势:
Vhost-user
随着技术的发展,将网络数据放入用户态处理将可以得到更灵活的形式。在原有的vhost架构中,进行了改动,增加了 一种新的vhost-backend,叫做vhost-user。
vhost的io路径
- guest设置好tx;
- kick host;
- guest陷出到kvm;
- vhost-net将tx数据投递到tap设备;
vhost-user的io路径
- guest设置好tx;
- kick host;
- guest陷出到kvm;
- kvm将通知snabb;
- snabb将tx数据直接发送到nic设备。
vhost-user的提交者是Luke Gorrie,他也是snabbswitch的作者。从图上可以看到vhost-backend从原来咋kernel中的vhost-net 变成了用户空间的snabbswitch。 snabbswitch直接接管物理网卡的驱动,从而直接控制网络信息的输入输出。
snabbswitch主要使用了下面的技术来提高性能
- 采用了大页来作为host和vm之间通信的内存空间
- 用户态操作网卡,使用类似于netmap的zero copy技术来加速对物理设备的访问
- 使用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介绍相关推荐
- KVM中virtio、vhost 和vhost-user比较(十一)
virtio 在虚拟机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的模拟网卡是非常一个不错的选择. 但是,e ...
- virtio、vhost和vhost-user比较
1. virtio:针对Linux的I/O的虚拟化框架 在虚机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的 ...
- 2021年二月下旬文章导读与开源项目仓库 | scatter-gather DMA,SR-IOV,ARP欺骗,中断,Lockdep,virtio,vhost
目录 文章目录 开源项目仓库 [转]浅谈scatter-gather DMA SR-IOV:网卡直通技术 [黑客入门] 连接公共WIFI有多危险(ARP欺骗) DPDK ACL算法介绍 文章目录 Li ...
- 高通Q+A Virtio hypervisor touch框架介绍(share-device)
背景 大家都知道现在高通芯片在汽车行业的座舱域运用比较热门,但是这种现象不是突然冒出来的,高通最早在2015年左右就开始推广他们的第一代座舱芯片820A.而在2018年左右开始推广他们的第二代产品(6 ...
- 数据平面开发套件(DPDK)中的Vhost / Virtio的配置和性能
目录 Vhost / Virtio简介 接收和发送路径 可合并路径 向量路径 不可合并的路径 PVP路径性能比较 I / O转发吞吐量 Mac转发吞吐量 PVP MAC转发吞吐量 测试台信息 关于作者 ...
- 异步模式下的 Vhost Packed Ring 设计介绍
引言 随着计算机硬件资源整合的发展,虚拟化的研究与应用日新月异.Virtio/Vhost作为一种设备虚拟化的典型应用,在业界受到了广泛的关注.Virtio 最开始由Rusty Russell在其200 ...
- VIRTIO VHOST
背景 在虚拟化领域,virtio 随处可见.当前,virtio 可以加速 IO.network子系统. 在 IO 子系统,主要有 virtio-blk, virtio-scsi.同时,有 vhost ...
- virtio,vhost 和vhost-user
virtio 在虚拟机中,可以通过qemu模拟e1000网卡,这样的经典网卡一般各种客户操作系统都会提供inbox驱动,所以从兼容性上来看,使用类似e1000的模拟网卡是非常一个不错的选择. 但是,e ...
- l298n电机驱动模块使用方法_SPDK virtio 驱动模块介绍及使用
作者简介闫亮 Intel高级软件工程师专注于开源存储SPDK的测试和优化 简介 CONTENTS SPDK virtio模块介绍 SPDK virtio 用户模式使用示例 SPDK virtio ...
最新文章
- CentOS5.4下安装短信猫
- NUXT: 视图和模板
- 折叠屏来了,开发者们准备好了吗?
- Extension project: 404 Not Found for resources/cus/crm/notes/ext/Component-dbg.js
- 【编译原理】CFG分析树
- 【CSS3】填色表格演示hsl()
- Nginx的client_header_buffer_size和large_client_header_buffers学习
- margin background_div盒子的外部距离(margin)【202】。
- 中职学校计算机基础的重要性,中职非计算机专业学生计算机基础教学浅探
- 基于全志a31s的camrea驱动调试(gc2145型号)
- 网站备案其实是服务器备案,网站备案指的是备案域名还是备案主机空间
- VSCode沙绿色主题设置
- 怎样将excel表格合并
- Licecap for Mac使用教程
- phpstorm License Server激活 官网下载版本直接激活
- 微信推出“微信圈子”,玩起来原来这么爽?
- 李沐动手学深度学习V2-机器翻译和数据集
- 26 27 28 副词
- 错误: 无法初始化主类
- 京东Java岗:来自面试官的夺命连环56问,直接当场怀疑人生~