浅析DPDK驱动管理:vhost

2024-02-17 21:36
文章标签 驱动 管理 浅析 dpdk vhost

本文主要是介绍浅析DPDK驱动管理:vhost,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 概述
    • DPDK vhost工作机制
      • DPDK vhost工作模式
    • DPDK vhost管理结构
    • DPDK vhost接口
      • 注册vhost驱动:rte_vhost_driver_register
      • 启动vhost:rte_vhost_driver_start
        • vhost消息处理
    • 相关参考

概述

DPDK提供了一套vhost库,用于加速virtio后端,对比于内核态的vhost方案,由于DPDK vhost是在用户态空间实现,因而也称作vhost-user。

DPDK vhost工作机制

DPDK vhost方案的核心是将数据面的处理放到用户空间中,而控制面的逻辑则通过Unix域套接字进行配置。DPDK vhost的整体框架如下:
在这里插入图片描述

DPDK应用程序作为单独的进程运行在宿主机上,通过Unix domain socket与QEMU完成设备控制信息的交互,包括设备属性、功能以及virtqueue配置等。virtio设备的模拟仍然由QEMU处理;在完成virtio设备的配置后,DPDK应用程序会以轮询的方式从VM的virtqueue中获得请求并进行处理。

DPDK vhost工作模式

DPDK vhost使用UNIX域套接字传输控制消息,根据vhost是作为server或client运行,vhost-user支持两种配置模式:

  • vhost-user:vhost-user作为服务端运行,创建Unix域套接字服务文件,并监听来自前端的连接。这是最初vhost-user支持的模式,但存在一旦DPDK业务进程挂掉,就会对所有VM造成影响;
  • vhost-user-client:vhost-user作为客户端运行,由DPDK业务进程负责发起对服务端的连接。

DPDK vhost管理结构

DPDK vhost核心数据结构关联如下:
在这里插入图片描述

其中:

  • vhost_user:vhost-user全局管理结构,维护所有vhost驱动
  • vhost_user_socket:对于每个vhost驱动,都维护着一个Unix domain socket,负责与外部应用进行通信;
  • vhost_user_connection:

DPDK vhost接口

DPDK本身提供的是一套vhost库接口,由上层应用通过调用对应的接口实现特定的vhost驱动,目前已有的实现包括DPDK自带的vhost-net驱动、SPDK基于DPDK vhost接口实现的vhost-blk和vhost-scsi驱动等。DPDK vhost提供的几个关键接口如下:

  • rte_vhost_driver_register:注册vhost驱动;
  • rte_vhost_driver_set_features:设置vhost驱动的feature信息;
  • rte_vhost_driver_callback_register:注册vhost驱动特定的回调,由vhost-user在合适的流程中进行调用;
  • rte_vhost_driver_start:启动vhost;
  • rte_vhost_enqueue_burst:从Host向Guest传输数据;
  • rte_vhost_dequeue_burst:从身体Guest接收数据。

注册vhost驱动:rte_vhost_driver_register

在这里插入图片描述

启动vhost:rte_vhost_driver_start

在这里插入图片描述

vhost消息处理

vhost_user_read_cb负责接收Unix domain socket的消息,并进行处理。
在这里插入图片描述

相关参考

  • Vhost Library

这篇关于浅析DPDK驱动管理:vhost的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/719052

相关文章

浅析Python中的绝对导入与相对导入

《浅析Python中的绝对导入与相对导入》这篇文章主要为大家详细介绍了Python中的绝对导入与相对导入的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1 Imports快速介绍2 import语句的语法2.1 基本使用2.2 导入声明的样式3 绝对import和相对i

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Linux内存泄露的原因排查和解决方案(内存管理方法)

《Linux内存泄露的原因排查和解决方案(内存管理方法)》文章主要介绍了运维团队在Linux处理LB服务内存暴涨、内存报警问题的过程,从发现问题、排查原因到制定解决方案,并从中学习了Linux内存管理... 目录一、问题二、排查过程三、解决方案四、内存管理方法1)linux内存寻址2)Linux分页机制3)

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

IDEA中的Kafka管理神器详解

《IDEA中的Kafka管理神器详解》这款基于IDEA插件实现的Kafka管理工具,能够在本地IDE环境中直接运行,简化了设置流程,为开发者提供了更加紧密集成、高效且直观的Kafka操作体验... 目录免安装:IDEA中的Kafka管理神器!简介安装必要的插件创建 Kafka 连接第一步:创建连接第二步:选

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti