您好我正在使用kue,cluster,redis,node.js。这是一个非常简单的例子,稍后我会从外面调用测试函数。
我的目的是将一些传入的作业添加到队列中并使用worker处理它。
在我的情况下,当用户使用我的应用程序完成订单时,他会收到一封电子邮件。我会将电子邮件详细信息发送到队列并使用工作人员进行处理。
var cluster = require('cluster');
var kue = require('kue');
var jobs = kue.createQueue();
var max_workers = 3;
function test() {
jobs.create('email', {
title: 'welcome email for tj'
, to: 'tj@learnboost.com'
, template: 'welcome-email'
}).save( function(err){
if( !err){} console.log( "no error");
});
if( cluster.isMaster ) {
for (var i = 0; i < max_workers; i++) {
cluster.fork();
console.log("forked -> "+i);
}
} else {
jobs.process('email', function(jobs, done){
console.log('Job', jobs.id, 'is done');
done && done();
});
}
}
setInterval(test,3000);
当我运行脚本node test.js
时,我得到了这个输出
forked -> 0
forked -> 1
forked -> 2
no error
forked -> 0
forked -> 1
forked -> 2
no error
no error
no error
no error
forked -> 0
forked -> 1
forked -> 2
no error
no error
no error
no error
no error
no error
no error
forked -> 0
forked -> 1
forked -> 2
no error
no error
no error
no error
no error
no error
no error
no error
no error
no error
forked -> 0
forked -> 1
forked -> 2
no error
no error
no error
no error
no error
no error
no error
no error
no error
no error
no error
no error
no error
forked -> 0
forked -> 1
forked -> 2
no error
no error
no error
no error
Job 176 is done
no error
Job 177 is done
no error
no error
no error
no error
no error
Job 178 is done
no error
no error
no error
Job 179 is done
no error
no error
no error
继续......
正如我所看到的,主进程是不时运行的,fork()子进程再次进行,并且还完成了工作。
我的问题是
我试着自己了解了几天,但仍然有疑问,如果有人能够解释这些背后的逻辑,那将非常感激:)
提前致谢。