【技术实现步骤摘要】
一种基于事件驱动和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
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。