Nodejs 请教 node.js 启动外部程序后的回收问题

发布于 1周前 作者 h691938207 来自 nodejs/Nestjs

Nodejs 请教 node.js 启动外部程序后的回收问题

  • 我用 C++开发了一个本地代理程序,它会启动额外的可执行程序。
  • 现在遇到一个问题:当这个本地代理程序被 node.js 启动后,当 node.js 退出的时候,我的本地代理程序该如何响应 node.js 的 kill 消息( windows 平台)?
  • 大家对本地代理程序被关闭的时候,额外的可执行程序应该如何关闭有什么建议吗?

8 回复

process 监听 SIGINT 和 SIGTERM,然后给本地代理程序发消息结束或者怎么样不就好了。

其实我建议有条件把 C++移植到 wasm,要死和 nodejs 一起死,省的相互通讯。


Unix 的话好像 process tree 会跟着关闭的,不过似乎通过 fork 可以脱离出去?具体情况我没了解过。
Windows 的话可以使用 Job Objects,把子进程都放在一个 Job 里面,然后设置 Job 释放时结束进程。这种方法直接启动子进程没办法绕过,只能依赖不在 Job 内的程序代替启动新进程才能绕过。
https://docs.microsoft.com/en-us/windows/win32/procthread/job-objects

然而监听不到这两个消息呢

对 wasm 不了解呢,有能直接转的工具吗?用到多线程的话不好转吧?

😅噢,原来还有 Emscripten 这样的工具啊

感谢大佬。感觉作业比较贴近 node 的底层实现👍

windows 平台可以启动一个线程调用 WaitForSingleObject 等待,nodejs 退出的时候会触发,然后通知主线程跟着退出

在 Node.js 中启动外部程序通常使用 child_process 模块,这个模块提供了多种方法来创建子进程,比如 execexecFilespawnfork。关于外部程序启动后的资源回收问题,主要涉及到如何正确管理和关闭子进程。

以下是一个使用 spawn 方法启动外部程序并处理其回收的示例:

const { spawn } = require('child_process');

// 启动外部程序,例如一个长时间运行的脚本
const child = spawn('node', ['longRunningScript.js']);

// 监听子进程的退出事件
child.on('close', (code) => {
  console.log(`子进程退出,退出码 ${code}`);
  // 可以在这里进行资源清理,比如关闭数据库连接等
});

// 在需要的时候,可以手动杀死子进程
// 例如,在接收到某个信号或满足某个条件时
process.on('SIGTERM', () => {
  console.log('接收到 SIGTERM 信号,终止子进程');
  child.kill('SIGTERM');
});

// 其他业务逻辑...

在这个示例中,我们使用 spawn 方法启动了一个外部 Node.js 脚本 longRunningScript.js。通过监听 close 事件,我们可以知道子进程何时退出,并进行相应的资源清理。此外,我们还展示了如何在接收到 SIGTERM 信号时手动杀死子进程,这通常用于优雅地关闭应用程序。

确保在实际应用中根据具体需求处理子进程的启动和回收,以避免资源泄漏或僵尸进程。

回到顶部