cluster模塊設置子進程的stdio
- 2019 年 12 月 12 日
- 筆記
原因
子進程的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)