golua虚拟机的使用

本文介绍了如何在golang开发的分布式流程调度系统中使用Gopher-Lua替代cgo版本的golua,以解决编译部署和执行效率问题。Gopher-Lua是一个纯Go实现的Lua5.1虚拟机,具有良好的API接口和性能。文章详细阐述了创建和使用lua虚拟机、在Go中调用lua函数以及允许lua脚本调用Go函数的方法,展示了Gopher-Lua在提供安全沙箱环境和增强lua脚本功能方面的优势。
摘要由CSDN通过智能技术生成

前言

之前一直想把openflow这样的分布式流程系统做起来,但是时间和应用场景的问题所以都是做了一个半拉子工程,而且之前想的也有点简单了,认为只要有同学愿意,在开发上应该没问题,但是最终还是出现了项目管理和开发能力的问题,最终搁浅了。但是我想做一个分布式流程调度系统的想法一直没有断,其实在公司内和另外一个同学做过一个flow系统,也在线上使用了,直到现在还在使用。前一段时间就想把这个系统再优化梳理一下,目标是做一个小巧的开源可用版本。经过一段时间的梳理目前已经初步完成了,后台+前端代码的重新梳理也已经完成了。

lua虚拟机的使用

而今天主要想写的是其中使用到的一个技术点:lua。内部版本我们使用的是golang开发,但是在执行中为了保证流程之间不会互相影响,我们使用lua虚拟机技术;让每个流程在执行的时候在一个独立的lua虚拟机中执行。内部版本使用golua这个组件,但是这个组件有个问题,它其实是一个cgo的版本,就是它其实上是调用本地lua库来执行,所在在编译部署和执行上都有一定的效率问题。

所以在新开发的版本上我想使用其它的方式,在研究了一段时间后决定使用gopher-lua这个组件,这个是使用golang重写的支持Lua5.1的虚拟机,在执行上可以直接golang无缝结合,有非常好的go的api接口,在使用上也流畅很多,在实现思路上也采用golang的一些思路,和golang结合更好。也通过这次学习了一把lua&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值