[发明专利]一种基于协程的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监听列表中;

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海浦东发展银行股份有限公司,未经上海浦东发展银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202111157853.2/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top