nodejs的process.on('message')转promise

本文详细介绍了在Node.js中使用子进程进行高效通信的方法,通过实例展示了如何利用Promise.all和sendMessage函数实现消息的发送与接收,同时处理超时情况,确保了进程间通信的稳定性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// main.js

const cp = require('child_process');
const child = cp.fork('./child.js');

const callbackPool = {};

child.on('message', msg => {
    let msgId = msg._id,
        cb = callbackPool[msgId];

    if (cb) {
        cb.resolve(msg);
        clearTimeout(cb.timer);
        callbackPool[msgId] = null;
    }
});

Promise.all([
    sendMessage({timeout: 1e3}),
    sendMessage({timeout: 2e3}),
    sendMessage({timeout: 2e3}),
    sendMessage({timeout: 1e3}),
]).then(rv => {
    log(rv);
}).catch(err => {
    log(err);
})


function sendMessage(msg, cb) {
    msg._id = (Math.random() * 1e6) | 0;
    child.send(msg);
    log('sent', msg);
    return new Promise((resolve, reject) => {
        let msgId = msg._id,
            timer = setTimeout(function() {
                let cb = callbackPool[msgId];
                if (cb) {
                    clearTimeout(cb.timer);
                    callbackPool[msgId] = null;
                }
                reject('timeout');
            }, 5e3);
        callbackPool[msgId] = { resolve, reject, timer };
    });
}


function log(...args) {
    args.unshift(new Date().toLocaleString());
    console.log.apply(console, args);
}

// child.js

process.on('message', msg => {
	doReply(msg);
});

function doReply(msg){
	setTimeout(() => {
		msg.data = msg._id * 2;
		sendMessage(msg);
	}, (msg.timeout || 0) * 2);
}

function sendMessage(msg){
	process.send(msg);
}

  

转载于:https://www.cnblogs.com/zh33gl/p/8422663.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值