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)