在Node.js应用程序和Lua应用程序之间共享数据
2014-9-10 7:34:7
收藏:0
阅读:75
评论:1
我有两个应用程序,一个运行在node-webkit上的Node.js应用程序和一个Lua应用程序。我需要在规律的时间间隔内在两个应用程序之间传递数据,比如每5到15秒一次。
Node.js应用程序创建数据,而Lua应用程序消耗数据。数据只会向一个方向移动。
我应该如何进行数据传输。我希望数据为json/xml格式,但实际上它也可以是其他格式。每次传输的数据并不多,只有一些参数。
我的初始想法是让Node应用程序充当服务器,并通过rest api提供数据,而Lua应用程序只需使用LuaSocket或类似工具阅读页面。但是,如果两个应用程序都驻留在同一台计算机上,是否有更好的方法进行传输?目前,Lua应用程序在Windows上运行,但这可能会改变。
我的背景是Web开发,所以在应用程序之间共享数据方面我完全迷失了。我对Lua也是新手。感谢任何答案。
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
有许多方法可以完成这样的任务。我将描述其中两种。
我最喜欢的第一种方法是使用远程队列,例如Apache Kafka、Redis、RabbitMQ,甚至是小数据时的Zookeeper,或者存储在数据库中。所有这些远程存储系统都有非常好的Node.js模块,它们都可以很好地处理JSON和任何其他数据类型。
除非这只是一个简单的测试应用程序,否则最好将这种容错性构建到应用程序中。在您的情况下,想象一下,如果消费者Lua应用程序崩溃了,或者相反,Node.js生产者应用程序崩溃了。您不希望一个应用程序的失败影响另一个应用程序。在生产环境中,最好像这样隔离应用程序和任务。此方法的另一个优点是,有一天您可能会决定在Node.js、Scala等中重写您的消费者,或者以不同的语言拥有多个消费者。这不需要您的服务器停止或更改。它甚至不必知道消费者的任何更改。
因此,您的生产服务器始终独立地将数据推送到远程数据存储/队列中,而消费者服务器按自己的节奏读取然后从该远程存储中删除数据。
如果使用了数据库,您将读取新记录、消耗它们,一旦完成,就会将它们从数据库中删除。这种方法允许您独立地关闭消费者和生产者应用程序,无论出于任何原因,例如升级。
另一种方法是通过TCP建立生产者服务器与消费者服务器之间的直接网络连接。生产者服务器将成为向消费者服务器推送数据的客户端。如果应用程序在不同的物理机器上,则可以使用
net内置模块来实现此目的。但是,正如您所看到的,这是一种不太可靠的解决方案,因为如果消费者崩溃,生产者将无法再推送新数据,在这种情况下,您应该考虑如何处理它:丢弃或存储在某个地方。如果存储在某个地方,您最终将重新实现上述第一种方法。