nodejs 任务调度bull 测试解析

集群

import {Util} from "../modules/core/utils";

const Queue = require('bull'),
    cluster = require('cluster');

const numWorkers = 8;

const queue = new Queue("nike", {
    redis: {port: 6379, host: '192.168.10.167', password: null},
    prefix: 'nike_',
    defaultJobOptions: {
        attempts: 1,
        removeOnComplete: true,
        backoff: false,
        delay: 0,
    },
    limiter: {
        max: 200000,
        duration: 1000,
    },
    settings: {
        maxStalledCount: 1,
        guardInterval: 1,//重新调度延迟
        retryProcessDelay: 500,// delay before processing next job in case of internal error.
        // drainDelay: 50000,
    },
});
let count = 0;
if (cluster.isMaster) {
    for (let i = 0; i < numWorkers; i++) {
        cluster.fork();
    }
    cluster.on('online', async (worker) => {
        for (let i = 0; i < 100; i++) {
            await queue.add({data: 1});
            console.log(await queue.count())
        }
    });

    //工作退出了
    cluster.on('exit', function (worker, code, signal) {
        console.log('worker ' + worker.process.pid + ' died');
    });
} else {
    queue.process(async (job) => {
        count++;
        await Util.Coder.sleep(2);
        console.log("Job done by worker", cluster.worker.id, job.id, count);
        return Promise.resolve();
    });
}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值