cluster模块设置子进程的stdio

原因

子进程的stdout及stderr需要被设置为某个文件,根据文档 setupMaster 说明,需要设置stdio数组:

c.setupMaster({
        exec: `${cwd}/c.js`,
        stdio: [0, 1, 2, 'ipc']
})

其中,stdio中的项可以为数组。

小问题

master.js

let c = require('cluster');
let fs = require('fs');
let path = require('path');
let cwd = process.cwd();

let o = fs.createWriteStream(path.join(cwd, 'out.log'));
c.setupMaster({
        exec: `${cwd}/c.js`,
        stdio: [0, o, o, 'ipc']
})
    
c.fork();

c.js

console.log(13324)
console.error('error')

如果直接这样使用,则会抛错

throw new errors.TypeError('ERR_INVALID_OPT_VALUE', 'stdio',
      ^
TypeError [ERR_INVALID_OPT_VALUE]: The value "WriteStream"

原因是stdio中的stream对象还未准备好,因此需要提前创建流。
如下:

let c = require('cluster');
let fs = require('fs');
let path = require('path');
let cwd = process.cwd();

let o = fs.createWriteStream(path.join(cwd, 'out.log'));

setTimeout(() => {
    c.setupMaster({
        exec: `${cwd}/c.js`,
        stdio: [0, o, o, 'ipc']
    })
    
    c.fork();
},10)
posted @   royalrover  阅读(368)  评论(0编辑  收藏  举报
编辑推荐:
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
阅读排行:
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)
点击右上角即可分享
微信分享提示