首页
技术博客
PHP教程
数据库技术
前端开发
HTML5
Nginx
php论坛
新用户注册
|
会员登录
PHP教程
技术博客
编程问答
PNG素材
编程语言
前端技术
Android
PHP教程
HTML5教程
数据库
Linux技术
Nginx技术
PHP安全
WebSerer
职场攻略
JavaScript
开放平台
业界资讯
大话程序猿
登录
极速注册
取消
热门标签 | HotTags
select
typescript
process
split
web
jar
client
node.js
heap
random
bytecode
window
chat
post
hook
vba
httprequest
c语言
hashtable
instance
js
usb
tags
get
bash
spring
nodejs
header
cpython
php7
triggers
ip
cSharp
cookie
timezone
javascript
python2
hash
replace
range
ascii
config
schema
php5
keyword
lua
uri
char
yaml
golang
uml
eval
list
tree
数组
buffer
bit
object
filter
shell
regex
testing
import
callback
format
export
match
flutter
datetime
cPlusPlus
vbscript
int
install
case
merge
default
dockerfile
version
actionscrip
当前位置:
开发笔记
>
编程语言
> 正文
深入解析RDMA中的队列对(QueuePair)
作者:mobiledu2502869467 | 来源:互联网 | 2024-12-21 11:16
本文将详细探讨RDMA架构中的关键组件——队列对(QueuePair,简称QP),包括其基本概念、硬件与软件实现、QPC的作用、QPN的分配机制以及用户接口和状态机。通过这些内容,读者可以更全面地理解QP在RDMA通信中的重要性和工作原理。
### 深入解析RDMA中的队列对(Queue Pair)
#### 基本概念回顾
队列对(Queue Pair,简称QP)是RDMA中连接硬件和软件的重要虚拟接口。它由发送队列(SQ)和接收队列(RQ)组成,用于存储软件下发给硬件的任务(WQE)。每个QP独立运作,彼此通过保护域(PD)隔离,确保一个QP可以被视为某个用户的独占资源。
QP支持多种服务类型,如可靠连接(RC)、不可靠数据报(UD)、可靠数据报(RD)和不可靠连接(UC)。所有源QP和目的QP必须为同一种类型才能进行数据交互。
#### 硬件与软件实现
从硬件角度看,QP是一段包含若干个WQE的存储空间,IB网卡会从中读取任务并执行相应的内存操作。这段存储空间可以位于内存或IB网卡的片内存储器中,具体实现由厂商决定。
从软件角度看,QP是由IB网卡驱动程序维护的数据结构,包含QP的地址指针及相关的属性信息。
#### QPC的作用
QPC(Queue Pair Context)是存储QP相关属性的数据结构,主要用于软硬件之间的同步。硬件只知道QP存储空间的起始地址和大小,而具体的WQE数量、当前处理位置等信息则由QPC提供。因此,QPC在硬件和驱动程序之间起到了桥梁作用。
#### QPN的分配机制
QPN(Queue Pair Number)是每个QP的唯一标识符,用24位表示,理论上每个节点最多可拥有16777216个QP。不同节点上的QP编号可以重复,但同一节点内的QP编号必须唯一。
有两个特殊的保留编号:
- **QP0**:用于子网管理接口(SMI),负责管理和配置子网中的所有节点。
- **QP1**:用于通用服务接口(GSI),主要用于通信建立前的信息交换。
#### 用户接口
用户接口分为控制面和数据面两部分。
- **控制面**:涉及QP的创建、销毁、修改和查询。常用的Verbs接口包括`ibv_create_qp`、`ibv_destroy_qp`、`ibv_modify_qp`和`ibv_query_qp`。
- **数据面**:涉及发送和接收请求的提交,即`Post Send Request`和`Post Receive Request`。这些操作允许用户向QP中填写WQE以发起或响应通信。
#### QP状态机
QP的状态机描述了QP的不同状态及其转换条件。主要状态包括:
- **RST(Reset)**:初始复位状态,QP无法接收或发送消息。
- **INIT(Initialized)**:已初始化状态,只能接收但不会处理消息。
- **RTR(Ready to Receive)**:准备接收状态,可以正常处理接收到的消息。
- **RTS(Ready to Send)**:准备发送状态,可以正常发送消息。
- **SQD(Send Queue Drain)**:发送队列排空状态,处理完现有WQE后才能处理新的请求。
- **SQEr(Send Queue Error)**:发送队列错误状态,当某个Send WR发生错误时进入此状态。
- **ERR(Error)**:错误状态,QP停止处理WQE,需修复后再重新初始化。
#### 总结
本文详细介绍了QP的基本概念、硬件与软件实现、QPC的作用、QPN的分配机制以及用户接口和状态机。作为RDMA的核心组件,QP的内容丰富且复杂,后续文章将继续深入探讨相关主题,如CQ等。
queue
https
队列
text
bit
int
service
io
算法
写下你的评论吧 !
吐个槽吧,看都看了
会员登录
|
用户注册
推荐阅读
get
微软Exchange服务器遭遇2022年版“千年虫”漏洞
微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ...
[详细]
蜡笔小新 2024-12-25 14:08:03
header
Servlet 表单处理:GET 和 POST 请求的深入解析
本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ...
[详细]
蜡笔小新 2024-12-23 18:09:59
get
并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ...
[详细]
蜡笔小新 2024-12-21 12:39:07
get
Transforming the Future of Virtual Worlds
Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ...
[详细]
蜡笔小新 2024-12-28 09:44:49
get
Java并发编程:LinkedBlockingQueue的实际应用
本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ...
[详细]
蜡笔小新 2024-12-27 18:51:49
get
Java面试题解析
本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ...
[详细]
蜡笔小新 2024-12-27 13:55:14
web
DNN Community 和 Professional 版本的主要差异
本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ...
[详细]
蜡笔小新 2024-12-27 13:14:08
bash
基于KVM的SRIOV直通配置及性能测试
SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ...
[详细]
蜡笔小新 2024-12-25 19:26:39
get
深入探讨CPU虚拟化与KVM内存管理
本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ...
[详细]
蜡笔小新 2024-12-25 19:15:51
spring
掌握Java EE的全面指南
探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ...
[详细]
蜡笔小新 2024-12-25 13:38:29
get
深入解析 Android IPC 中的 Messenger 机制
本文详细介绍了 Android 中基于消息传递的进程间通信(IPC)机制——Messenger。通过实例和源码分析,帮助开发者更好地理解和使用这一高效的通信工具。 ...
[详细]
蜡笔小新 2024-12-21 11:11:40
bash
网络链路质量监控:Smokeping部署与配置
本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ...
[详细]
蜡笔小新 2024-12-27 19:31:05
bash
深入解析TCP/IP五层协议
本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ...
[详细]
蜡笔小新 2024-12-24 14:02:48
nodejs
FinOps 与 Serverless 的结合:破解云成本难题
本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ...
[详细]
蜡笔小新 2024-12-24 12:44:26
nodejs
深入解析Redis内存对象模型
本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ...
[详细]
蜡笔小新 2024-12-23 14:50:23
mobiledu2502869467
这个家伙很懒,什么也没留下!
Tags | 热门标签
select
typescript
process
split
web
jar
client
node.js
heap
random
bytecode
window
chat
post
hook
vba
httprequest
c语言
hashtable
instance
js
usb
tags
get
bash
spring
nodejs
header
cpython
php7
RankList | 热门文章
1
Bootstrap4 输入框组件详解
2
面试算法题:字符串空格替换
3
php空间能运行python吗,可以在php函数中运行Python吗?
4
MySQL 存储程序详解
5
深入解析stopPropagation与cancelBubble的区别
6
Vue 中安装 less-loader 时遇到的问题与解决方法
7
Java基础概念与核心特性解析
8
获取所有ActiveSync设备信息的方法
9
如何在技嘉M52LT-D3主板上启用VT功能
10
SQL 中的 CHECK 约束详解
11
深入理解MySQL基础:SQL语言的应用与实践
12
Python中使用字典作为函数参数的方法
13
在命令行中加参数的文件复制程序
14
考研复试计算机网络面试题问题
15
使用iPubsoft PDF Converter高效转换PDF至PPT
PHP1.CN | 中国最专业的PHP中文社区 |
DevBox开发工具箱
|
json解析格式化
|
PHP资讯
|
PHP教程
|
数据库技术
|
服务器技术
|
前端开发技术
|
PHP框架
|
开发工具
|
在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved |
京公网安备 11010802041100号
|
京ICP备19059560号-4
| PHP1.CN 第一PHP社区 版权所有