IPC在两个不相关的节点js进程之间使用共享内存通信

Posted

技术标签:

【中文标题】IPC在两个不相关的节点js进程之间使用共享内存通信【英文标题】:IPC using shared memory communication between two unrelated node js processes 【发布时间】:2020-04-26 12:19:30 【问题描述】:

我有两个不相关的节点 js 进程在同一台 Windows 机器上运行。我希望这两个进程相互通信,但不使用 FileIO(性能问题)和 Sockets(安全问题)。我们有什么办法可以做到吗?我已阅读有关共享内存和基于管道的通信的信息,但找不到节点 js 的任何实现。

【问题讨论】:

【参考方案1】:

这个问题的答案取决于一个节点进程是否正在启动另一个。如果一个节点进程使用fork() 启动另一个节点进程,则它可以使用process.send()process.on('message', ...) 进行通信。

见https://nodejs.org/api/child_process.html#child_process_subprocess_send_message_sendhandle_options_callback

// parent.js
const cp = require('child_process');
const n = cp.fork(`$__dirname/sub.js`);

n.on('message', (m) => 
  console.log('PARENT got message:', m);
);

// Causes the child to print: CHILD got message:  hello: 'world' 
n.send( hello: 'world' );

对于子进程:

// child.js

process.on('message', (m) => 
  console.log('CHILD got message:', m);
);

// Causes the parent to print: PARENT got message:  foo: 'bar', baz: null 
process.send( foo: 'bar', baz: NaN );

如果在另一个句柄上,进程是单独启动的,那就是另一回事了。

这首先引出了一个问题,当您说出于安全原因不想使用套接字时,您的意思是什么?

您是否担心可以从计算机外部访问您的节点进程。因为只有当您绑定到 IP 地址 0.0.0.0 或您的公共 IP 地址之一时才会发生这种情况。如果您绑定到 127.0.0.1,则不会发生这种情况,那么它应该只能从您的计算机访问。

前往 127.0.0.1 的流量也会绕过网络工作,因此它永远不会离开您的计算机或进入您的网卡。

您还可以使用更难访问的本地命名套接字。

如果您担心其他本地服务能够与您的频道通信,您可以通过传递秘密信息或加密内容来解决这个问题。

您可以在以下 Stack Overflow 答案中找到有关使用命名套接字和管道的更多详细信息:How to create a named pipe in node.js?

【讨论】:

抱歉回复晚了。感谢@luis 提供有关安全相关 Socket 的清晰信息。我不知道。我们已经验证了该信息并正在使用“命名管道”解决方案。除此之外,您的第一个解决方案是针对子进程,我在标题中明确提到进程是不相关的,因此我们不能对这些进程使用标准输入和标准输出。

以上是关于IPC在两个不相关的节点js进程之间使用共享内存通信的主要内容,如果未能解决你的问题,请参考以下文章

linux进程间的通信之 共享内存

linux进程间的通信(C): 共享内存

linux c编程:Posix共享内存区

两个不相关的进程如何知道相同的密钥来分配相同的共享内存

进程间通信:共享内存

IPC通信_共享内存