vhost-kernel方案相较于virtio-scsi优化了host上的io,但是仍然存在通知的开销,guest需要通知qemu,qemu需要通知host kernel vhost-scsi,于是进一步演进出了vhost-user方案: 整体架构如上图所示,virtio backend仍然在host用户态,但是放到了qemu外部,vhost作为独立进程运行在host用户态,通过hugepage的共享内存和qemu共享vierque...
使用vhost-user技术,从虚拟机到host上实现了数据的zero copy(通过大页共享),host到nic的zero copy(snabbswitch实现的驱动),能进一步加快数据的传输。 DPDK便是一个在用户态可以直接操作物理网卡的库函数,它和vhost-user结合便可以实现类似于snabb switch一样性能强劲的用户态交换机了。 vhost-user数据面:基于virtqueue...
vhost-user 和 vhost_net 的实现原理是一样,都是采用 vring 完成共享内存,eventfd 机制完成事件通知。不同在于 vhost_net 实现在内核中,而 vhost-user 实现在用户空间中,用于用户空间中两个进程之间的通信,其采用共享内存的通信方式。 vhost-user 基于 C/S 的模式,采用 UNIX 域套接字(UNIX domain socket)来完...
在原有的vhost架构中,进行了改动,增加了 一种新的vhost-backend,叫做vhost-user。 vhost-user的io路径: guest设置好tx kick host guest陷出到kvm kvm将通知vhost-backend vhost-backend将tx数据直接发送到nic设备 vhost-user的提交者是Luke Gorrie,他也是snabbswitch的作者。从图上可以看到vhost-backend从原来咋kernel...
而vhost-user则是vhost的进一步发展,将部分驱动操作移到用户态,通过snabbswitch(用户空间的网络驱动)直接操控物理网卡,实现了数据的zero copy,极大地提高了数据传输速度。dpdk库的结合使得用户态交换机性能更强劲,其数据面基于virtqueue,由descriptor table、available ring和used ring组成,控制面则基于...
使用vhost-user技术,从虚拟机到host上实现了数据的zero copy(通过大页共享),host到nic的zero copy(snabbswitch实现的驱动),能进一步加快数据的传输。 DPDK便是一个在用户态可以直接操作物理网卡的库函数,它和vhost-user结合便可以实现类似于snabb switch一样性能强劲的用户态交换机了。
同时,该技术框架对 vhost 内核子系统进行了扩展,赋予了类似 VFIO 技术框架的功能,允许将 vDPA 设备用来进行数据通信的硬件资源(ring buffer, deor table,doorbell 寄存器等)透传给虚机使用,这样,虚拟机的 virtio 驱动进行数据通信时,也是直接访问硬件资源,而不再需要通过 vhost、vhost-user 等方式进行处理了。更重要...
1. 特性协商:virtio的特性与vhost-user新定义的特性都可以通过类似的方式协商,而所谓协商的具体实现就是QEMU接收vhost-user的特性,与自己支持的特性取交集。 2. 内存区域配置:QEMU配置好内存映射区域,vhost-user使用mmap接口来映射它们。 3. Vring配置:QEMU将Virtqueue的个数与地址发送给vhost-user,以便vhost-user访问...
同时,该技术框架对 vhost 内核子系统进行了扩展,赋予了类似 VFIO 技术框架的功能,允许将 vDPA 设备用来进行数据通信的硬件资源(ring buffer, deor table,doorbell 寄存器等)透传给虚机使用,这样,虚拟机的 virtio 驱动进行数据通信时,也是直接访问硬件资源,而不再需要通过 vhost、vhost-user 等方式进行处理了。更重要...
4 vhost-user 4.1 什么是 vhost-user 在vhost_net 的方案中,由于 vhost_net 实现在内核中,guest 与 vhost_net 的通信,相较于原生的 virtio 方式性能上有了一定程度的提升,从 guest 到 kvm.ko 的交互只有一次用户态的切换以及数据拷贝。这个方案对于不同 host 之间的通信,或者 guest 到 host nic 之间的通信...