1

我有一个应用程序(主),它将工作分配给 n 数量的工人。在工作人员内部,js我将控制台输出挂钩如下:

console._log = console.log;
console._error = console.error;
console.log = (...args) => {
    process.send({
        cmd:'log',
        channel:'out',
        data: args.join(' ')
    });
};

console.error = (...args) => {
    process.send({
        cmd:'log',
        channel:'err',
        data: args.join(' ')
    });
};

master 现在负责将所有传入消息记录到 std 之外的文件中。完成以下代码和模块:

const intercept = require('intercept-stdout');
const stripAnsi = require('strip-ansi');

const unhook_intercept = intercept(function (str) {

    // stdout

    fs.appendFileSync(lib.logOutFile(), stripAnsi(str));

}, function (str) {

    // stderr

    fs.appendFileSync(lib.logErrFile(), stripAnsi(str));

});

我在日志中注意到一名工人在 1.5 天后停止发送消息。在主人我有工人退出检测:

cluster.on('exit', (worker, code, signal) => {

    if (signal) {

        console.log(`${lib.dateTimeStamp()} - ${chalk.magenta('[')}${chalk.cyan(worker.process.pid)}${chalk.magenta(']')}\tWorker: ${chalk.yellow(`was killed by signal: ${signal}`)}`);

    } else if (code !== 0) {

        console.error(`${lib.dateTimeStamp()} - ${chalk.magenta('[')}${chalk.cyan(worker.process.pid)}${chalk.magenta(']')}\tWorker: ${chalk.red(`exited with error code: ${code}`)}`);

        let newWorker = cluster.fork();
        let data = work[worker.process.pid];
        let d = new Date();

        status[worker.process.pid].status = 'dead';
        status[newWorker.process.pid] = {
            started: `${d.toLocaleDateString()} ${d.toLocaleTimeString()}`,
            status: 'alive'
        };

        delete work[worker.process.pid];

        work[newWorker.process.pid] = data;

        newWorker.send({
            options: cfg.options,
            websites: work[newWorker.process.pid]
        });

    } else {

        delete work[worker.process.pid];
        delete status[worker.process.pid]

        console.log(`${lib.dateTimeStamp()} - ${chalk.magenta('[')}${chalk.cyan(worker.process.pid)}${chalk.magenta(']')}\tWorker: ${chalk.green('exited successfully')}`);

    }

});

正如我在日志中看到的那样,没有触发退出。目前我只有假设,我想听听你的意见。会不会是因为:

  1. 同步文件日志记录。
  2. 一名工人自行断开连接。
  3. 一个工人退出了,退出事件被错过了。
  4. 你的意见...
4

0 回答 0