在Node.js中的两个不同进程之间进行通信

在Node.js中的两个不同进程之间进行通信,第1张

在Node.js中的两个不同进程之间进行通信

您描述的用例让我想到了dnode,您可以使用它轻松地公开由不同进程调用的函数,这些进程由使用网络套接字(和socket.io的dnode协调),因此您可以在浏览器中使用相同的机制。

另一种方法是使用消息队列,不同的消息队列有很多良好的绑定。

据我所知,最简单的方法是使用child_process.fork():

这是生成

spawn()
节点进程的功能的特例。除了在普通的ChildProcess实例中包含所有方法之外,返回的对象还内置了一个通信通道。子频道上的事件写入
child.send(message,[sendHandle])
并通过该
'message'
事件接收消息。

因此,对于您的示例,您可以有example2.js:

var fork = require('child_process').fork;var example1 = fork(__dirname + '/example1.js');example1.on('message', function(response) {  console.log(response);});example1.send({func: 'input'});

和example1.js:

function func(input) {  process.send('Hello ' + input);}process.on('message', function(m) {  func(m);});


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5126946.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-17

发表评论

登录后才能评论

评论列表(0条)

保存