[发明专利]一种基于事件驱动和lua协程的异步通信方法及装置在审

专利信息
申请号: 202010791413.1 申请日: 2020-08-07
公开(公告)号: CN111897667A 公开(公告)日: 2020-11-06
发明(设计)人: 戴磊;范渊;吴卓群 申请(专利权)人: 杭州安恒信息技术股份有限公司
主分类号: G06F9/54 分类号: G06F9/54;G06F9/52
代理公司: 北京集佳知识产权代理有限公司 11227 代理人: 张春辉
地址: 310000 浙江省*** 国省代码: 浙江;33
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 基于 事件 驱动 lua 异步 通信 方法 装置
【说明书】:

本申请公开了一种基于事件驱动和lua协程的异步通信方法、装置、设备及可读存储介质,针对高并发场景下网络请求耗时较多的问题,本申请利用高性能事件驱动结合lua脚本语言内部的协程特性,在任何一个协程在遇到网络耗时操作时,都会暂时挂起该协程,并继续执行下一个协程,所以不会由于部分协程的网络操作执行慢而耽误其他协程的执行,实现全程异步无阻塞,显著提升高并发场景下的通信性能。

技术领域

本申请涉及通信技术领域,特别涉及一种基于事件驱动和lua协程的异步通信方法、装置、设备及可读存储介质。

背景技术

传统的高并发开发模式一般包括两种:

一种是多进程或者多线程阻塞式,虽说这种方式也能实现并发,但是当并发量达到千、万甚至几十万时由于线程数或者进程数太多,CPU切换成本非常大,性能会极度下降。

另一种是单进程非阻塞式异步轮询,比如poll,select等,虽然在高并发情况下没有进程或者线程间切换的开销,但是每次都要在所有连接中轮询遍历,找到哪些连接有读写操作,并发量特别大时也非常耗性能。

可见,如何提供一种高并发场景下的通信方案,提升通信性能,是亟待本领域技术人员解决的问题。

发明内容

本申请的目的是提供一种基于事件驱动和lua协程的异步通信方法、装置、设备及可读存储介质,用以解决当前的通信方案在高并发场景下的性能较低的问题。其具体方案如下:

第一方面,本申请提供了一种基于事件驱动和lua协程的异步通信方法,包括:

利用lua语言声明目标全局对象,并加载预先创建的非阻塞式的网络相关函数;

根据所述目标全局对象,生成目标数量的协程;

依次调用每个协程执行相应的lua脚本,若当前协程执行到所述网络相关函数,则挂起当前协程,将所述网络相关函数的结果返回事件注册到操作系统的事件监听器,调用下一协程直至所述目标数量的协程全部调用完毕;

在所述事件监听器监听到所述结果返回事件时,调用相应的协程继续执行lua脚本。

优选的,在所述利用lua语言声明全局对象,并加载预先创建的非阻塞式的网络相关函数之前,还包括:

基于C语言,生成非阻塞式的网络相关函数。

优选的,所述生成非阻塞式的网络相关函数,包括:

根据lua自带的网络相关函数,生成相应的非阻塞式的网络相关函数。

优选的,所述依次调用每个协程执行相应的lua脚本,包括:

利用lua语言的resume方法,依次启动各个协程,依次调用每个协程执行相应的lua脚本。

优选的,所述若当前协程执行到所述网络相关函数,则挂起当前协程,包括:

若当前协程执行到所述网络相关函数,则利用lua语言的yield方法,挂起当前协程。

优选的,所述在所述事件监听器监听到所述结果返回事件时,调用相应的协程继续执行lua脚本之后,还包括:

若协程再次执行到所述网络相关函数,则挂起该协程,将所述网络相关函数的结果返回事件注册到所述事件监听器,继续等待所述事件监听器的反馈信息。

优选的,所述根据所述目标全局对象,生成目标数量的协程,包括:

根据待进行通信的客户端,确定目标数量;

根据所述目标全局对象,生成所述目标数量的协程。

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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