[发明专利]一种基于事件驱动和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脚本之后,还包括:
若协程再次执行到所述网络相关函数,则挂起该协程,将所述网络相关函数的结果返回事件注册到所述事件监听器,继续等待所述事件监听器的反馈信息。
优选的,所述根据所述目标全局对象,生成目标数量的协程,包括:
根据待进行通信的客户端,确定目标数量;
根据所述目标全局对象,生成所述目标数量的协程。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州安恒信息技术股份有限公司,未经杭州安恒信息技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010791413.1/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种建筑用悬挑底梁搁置端自脱式锚具
- 下一篇:一种用于加工中心的转台夹持装置