一种基于事件驱动和lua协程的异步通信方法及装置制造方法及图纸

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

【技术实现步骤摘要】
一种基于事件驱动和lua协程的异步通信方法及装置
本申请涉及通信
,特别涉及一种基于事件驱动和lua协程的异步通信方法、装置、设备及可读存储介质。
技术介绍
传统的高并发开发模式一般包括两种:一种是多进程或者多线程阻塞式,虽说这种方式也能实现并发,但是当并发量达到千、万甚至几十万时由于线程数或者进程数太多,CPU切换成本非常大,性能会极度下降。另一种是单进程非阻塞式异步轮询,比如poll,select等,虽然在高并发情况下没有进程或者线程间切换的开销,但是每次都要在所有连接中轮询遍历,找到哪些连接有读写操作,并发量特别大时也非常耗性能。可见,如何提供一种高并发场景下的通信方案,提升通信性能,是亟待本领域技术人员解决的问题。
技术实现思路
本申请的目的是提供一种基于事件驱动和lua协程的异步通信方法、装置、设备及可读存储介质,用以解决当前的通信方案在高并发场景下的性能较低的问题。其具体方案如下:第一方面,本申请提供了一种基于事件驱动和lua协程的异步通信方法,包括:r>利用lua语言声本文档来自技高网...

【技术保护点】
1.一种基于事件驱动和lua协程的异步通信方法,其特征在于,包括:/n利用lua语言声明目标全局对象,并加载预先创建的非阻塞式的网络相关函数;/n根据所述目标全局对象,生成目标数量的协程;/n依次调用每个协程执行相应的lua脚本,若当前协程执行到所述网络相关函数,则挂起当前协程,将所述网络相关函数的结果返回事件注册到操作系统的事件监听器,调用下一协程直至所述目标数量的协程全部调用完毕;/n在所述事件监听器监听到所述结果返回事件时,调用相应的协程继续执行lua脚本。/n

【技术特征摘要】
1.一种基于事件驱动和lua协程的异步通信方法,其特征在于,包括:
利用lua语言声明目标全局对象,并加载预先创建的非阻塞式的网络相关函数;
根据所述目标全局对象,生成目标数量的协程;
依次调用每个协程执行相应的lua脚本,若当前协程执行到所述网络相关函数,则挂起当前协程,将所述网络相关函数的结果返回事件注册到操作系统的事件监听器,调用下一协程直至所述目标数量的协程全部调用完毕;
在所述事件监听器监听到所述结果返回事件时,调用相应的协程继续执行lua脚本。


2.如权利要求1所述的方法,其特征在于,在所述利用lua语言声明全局对象,并加载预先创建的非阻塞式的网络相关函数之前,还包括:
基于C语言,生成非阻塞式的网络相关函数。


3.如权利要求2所述的方法,其特征在于,所述生成非阻塞式的网络相关函数,包括:
根据lua自带的网络相关函数,生成相应的非阻塞式的网络相关函数。


4.如权利要求1所述的方法,其特征在于,所述依次调用每个协程执行相应的lua脚本,包括:
利用lua语言的resume方法,依次启动各个协程,依次调用每个协程执行相应的lua脚本。


5.如权利要求4所述的方法,其特征在于,所述若当前协程执行到所述网络相关函数,则挂起当前协程,包括:
若当前协程执行到所述网络相关函数,则利用lua语言的yield方法,挂起当前协程。


6.如权利要求1所述的方法,其特征在于,所述在所述事件监听器监听到所述结果返回事件时,调用相应的协程继续执行lua脚本之...

【专利技术属性】
技术研发人员:戴磊范渊吴卓群
申请(专利权)人:杭州安恒信息技术股份有限公司
类型:发明
国别省市:浙江;33

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1