[发明专利]一种基于协程的RDMA通信方法、装置及存储介质在审

专利信息
申请号: 202111157853.2 申请日: 2021-09-30
公开(公告)号: CN114090483A 公开(公告)日: 2022-02-25
发明(设计)人: 张培承;周祥为;宋鹏光;李毅伦;余超;秦文劭;万化 申请(专利权)人: 上海浦东发展银行股份有限公司
主分类号: G06F13/28 分类号: G06F13/28;G06F9/50
代理公司: 广州华进联合专利商标代理有限公司 44224 代理人: 阚传猛
地址: 200001 *** 国省代码: 上海;31
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 基于 rdma 通信 方法 装置 存储 介质
【权利要求书】:

1.一种基于协程的RDMA通信方法,其特征在于,包括:

创建RDMA的目标对象,将所述目标对象映射为RDMA文件描述符,所述RDMA文件描述符设置为非阻塞模式;

将所述RDMA文件描述符封装为Golang的网络文件描述符;

将所述Golang的网络文件描述符注册到epoll监听列表中;

对所述epoll监听列表的网络文件描述符进行监听;

若监听到I/O事件,则使用Golang的goroutine协程调度机制对协程进行资源调度,实现RDMA的数据连接管理和/或数据传输。

2.一种基于协程的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监听列表中;

调用rdma_get_cm_event()执行I/O事件监听;执行Golang的goroutine调度,此时netFD当前所在的GO协程G执行gopark(),G的状态由_Grunning状态变为_Gwaitting状态,被放置到等待队列,直到所述netFD上发生I/O事件;当有客户端连接服务器时,所述netFD对应的文件描述符产生可读事件,通过Go scheduler循环调度的runtime.schedule()函数以及sysmon监控线程中调用runtime.nepoll,获取可运行的goroutine列表并将所述协程G放入全局调度队列或者当前P的本地调度队列去重新执行所述协程G;

rdma_get_cm_event()执行完成后,返回通信事件,将与各个事件及连接相关的信息进行保存之后,调用rdma_ack_cm_event()进行确认。

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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