[发明专利]一种基于协程的RDMA通信方法、装置及存储介质在审
申请号: | 202111157853.2 | 申请日: | 2021-09-30 |
公开(公告)号: | CN114090483A | 公开(公告)日: | 2022-02-25 |
发明(设计)人: | 张培承;周祥为;宋鹏光;李毅伦;余超;秦文劭;万化 | 申请(专利权)人: | 上海浦东发展银行股份有限公司 |
主分类号: | G06F13/28 | 分类号: | G06F13/28;G06F9/50 |
代理公司: | 广州华进联合专利商标代理有限公司 44224 | 代理人: | 阚传猛 |
地址: | 200001 *** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 rdma 通信 方法 装置 存储 介质 | ||
本公开关于一种基于协程的RDMA通信方法、装置及存储介质。该方法包括:创建RDMA的目标对象,将所述目标对象映射为RDMA文件描述符,所述RDMA文件描述符设置为非阻塞模式;将所述RDMA文件描述符封装为Golang的网络文件描述符;对所述epoll监听列表中的网络文件描述符进行监听;当监听到I/O事件时,使用Golang的goroutine协程调度机制对协程进行资源调度,实现RDMA的数据连接管理和/或数据传输。本公开实施例可以降低RDMA通信中的I/O多路复用技术的线程切换开销,解决了现有的Golang网络无法利用支持RDMA的硬件进行更高效的数据传输问题。
技术领域
本公开涉及网络通信数据处理技术领域,尤其涉及一种基于协程的RDMA通信方法、装置、电子设备及存储介质。
背景技术
目前,现有RDMA(Remote Direct Memory Acces,远程直接数据存取)通信的编程实现一般基于传统线程调度模型进行,即用户线程:内核线程的比例为1:1。若使用I/O多路复用技术,则将当前线程加入epoll等待队列,以及产生I/O事件切换会当前线程执行时,都需要触发系统中断,涉及到用户态与内核态的切换,同时还需要执行较多寄存器操作。
现有技术采用基于线程调度模型的I/O多路复用技术在提供处理大量并发请求时,由于线程是CPU调度与执行的最小单位,在主流操作系统如Linux或者其他类似的系统上,线程的栈大小一般是固定8MB,不能动态伸缩,这就导致了若同时存在大量线程,将会占用较大的内存空间。并且,执行线程之间的切换时产生开销也较大,如涉及到操作系统从用户态切换到内核态时,要刷新16个寄存器等操作。
发明内容
本公开提供一种基于协程的RDMA通信方法、装置、电子设备及存储介质,以至少解决相关技术中基于现场的RDMA通信占用内存大或线程开销大的技术问题。本公开的技术方案如下:
一种基于协程的RDMA通信方法,包括:
创建RDMA的目标对象,将所述目标对象映射为RDMA文件描述符,所述RDMA文件描述符设置为非阻塞模式;
将所述RDMA文件描述符封装为Golang的网络文件描述符;
将所述Golang的网络文件描述符注册到epoll监听列表中;
对所述epoll监听列表中的网络文件描述符进行监听;
若监听到I/O事件,则使用Golang的goroutine协程调度机制对协程进行资源调度,实现RDMA的数据连接管理和/或数据传输。
一种基于协程的RDMA通信方法,包括:
调用rdma_create_id()创建一个RDMA网络套接字,获取所述RDMA网络套接字的文件描述符,记为rdmaFD,将rdmaFD设为非阻塞模式;
将所述rdmaFD封装为Golang的第一网络文件描述符,记为netFD;
执行rdma_bind_addr(),将所述netFD对应的RDMA网络套接字与本地rdma网卡设备进行bind绑定;
执行rdma_listen()完成对所述netFD的监听;
调用Golang pollDesc.init(),完成epoll实例创建,并将所述netFD注册到epoll监听列表中;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海浦东发展银行股份有限公司,未经上海浦东发展银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111157853.2/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种动力电池温度控制方法及相关设备
- 下一篇:投资项目全流程管理方法及系统