在Node.js应用程序和Lua应用程序之间共享数据

我有两个应用程序,一个运行在node-webkit上的Node.js应用程序和一个Lua应用程序。我需要在规律的时间间隔内在两个应用程序之间传递数据,比如每5到15秒一次。

Node.js应用程序创建数据,而Lua应用程序消耗数据。数据只会向一个方向移动。

我应该如何进行数据传输。我希望数据为json/xml格式,但实际上它也可以是其他格式。每次传输的数据并不多,只有一些参数。

我的初始想法是让Node应用程序充当服务器,并通过rest api提供数据,而Lua应用程序只需使用LuaSocket或类似工具阅读页面。但是,如果两个应用程序都驻留在同一台计算机上,是否有更好的方法进行传输?目前,Lua应用程序在Windows上运行,但这可能会改变。

我的背景是Web开发,所以在应用程序之间共享数据方面我完全迷失了。我对Lua也是新手。感谢任何答案。

点赞
用户556678
用户556678

有许多方法可以完成这样的任务。我将描述其中两种。

我最喜欢的第一种方法是使用远程队列,例如Apache Kafka、Redis、RabbitMQ,甚至是小数据时的Zookeeper,或者存储在数据库中。所有这些远程存储系统都有非常好的Node.js模块,它们都可以很好地处理JSON和任何其他数据类型。

除非这只是一个简单的测试应用程序,否则最好将这种容错性构建到应用程序中。在您的情况下,想象一下,如果消费者Lua应用程序崩溃了,或者相反,Node.js生产者应用程序崩溃了。您不希望一个应用程序的失败影响另一个应用程序。在生产环境中,最好像这样隔离应用程序和任务。此方法的另一个优点是,有一天您可能会决定在Node.js、Scala等中重写您的消费者,或者以不同的语言拥有多个消费者。这不需要您的服务器停止或更改。它甚至不必知道消费者的任何更改。

因此,您的生产服务器始终独立地将数据推送到远程数据存储/队列中,而消费者服务器按自己的节奏读取然后从该远程存储中删除数据。

如果使用了数据库,您将读取新记录、消耗它们,一旦完成,就会将它们从数据库中删除。这种方法允许您独立地关闭消费者和生产者应用程序,无论出于任何原因,例如升级。

另一种方法是通过TCP建立生产者服务器与消费者服务器之间的直接网络连接。生产者服务器将成为向消费者服务器推送数据的客户端。如果应用程序在不同的物理机器上,则可以使用net内置模块来实现此目的。但是,正如您所看到的,这是一种不太可靠的解决方案,因为如果消费者崩溃,生产者将无法再推送新数据,在这种情况下,您应该考虑如何处理它:丢弃或存储在某个地方。如果存储在某个地方,您最终将重新实现上述第一种方法。

2014-09-10 08:59:24