[发明专利]一种基于协程的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()进行确认。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海浦东发展银行股份有限公司,未经上海浦东发展银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111157853.2/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种动力电池温度控制方法及相关设备
- 下一篇:投资项目全流程管理方法及系统