【发布时间】:2012-01-27 11:17:31
【问题描述】:
如果系统中已有相同的作业,我希望jobs.create 失败。有什么办法可以实现吗?
我需要每 24 小时运行一次相同的作业,但有些作业可能需要超过 24 小时,因此我需要确保在添加之前该作业尚未在系统中(活动、排队或失败)它。
更新: 好的,我将简化问题以便能够在这里进行解释。 恐怕我有一个分析服务,我必须每天向我的用户发送一次报告。有时完成这些报告(只是少数情况,但有可能)需要几个小时甚至超过一天。
我需要一种方法来了解哪些是当前正在运行的作业,以避免重复作业。我在 ´´´´kue´´´´ API 中找不到任何东西来了解当前正在运行哪些作业。我还需要在需要更多工作时触发某种事件,然后致电我的getMoreJobs 生产者。
也许我的方法是错误的,如果是这样,请告诉我一个更好的方法来解决我的问题。
这是我的简化代码:
var kue = require('kue'),
cluster = require('cluster'),
numCPUs = require('os').cpus().length;
numCPUs = CONFIG.sync.workers || numCPUs;
var jobs = kue.createQueue();
if (cluster.isMaster) {
console.log('Starting master pid:' + process.pid);
jobs.on('job complete', function(id){
kue.Job.get(id, function(err, job){
if (err || !job) return;
job.remove(function(err){
if (err) throw err;
console.log('removed completed job #%d', job.id);
});
});
function getMoreJobs() {
console.log('looking for more jobs...');
getOutdateReports(function (err, reports) {
if (err) return setTimeout(getMoreJobs, 5 * 60 * 60 * 1000);
reports.forEach(function(report) {
jobs.create('reports', {
id: report.id,
title: report.name,
params: report.params
}).attempts(5).save();
});
setTimeout(getMoreJobs, 60 * 60 * 1000);
});
}
//Create the jobs
getMoreJobs();
console.log('Starting ', numCPUs, ' workers');
for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('death', function(worker) {
console.log('worker pid:' + worker.pid + ' died!'.bold.red);
});
} else {
//Process the jobs
console.log('Starting worker pid:' + process.pid);
jobs.process('reports', 20, function(job, done){
//completing my work here
veryHardWorkGeneratingReports(function(err) {
if (err) return done(err);
return done();
});
});
}
【问题讨论】:
-
需要更多信息,代码什么的...
-
@Teemu 我已经更新了我的问题,谢谢!
标签: javascript node.js parallel-processing