KUE可以执行外部流程吗?

时间:2014-10-21 06:03:14

标签: node.js process kue

是否可以将脚本排队并执行为KUE https://github.com/LearnBoost/kue中的作业?

脚本如/usr/bin/myScript.sh -a 10 -b 20 -c 30
我看到的所有示例都假定作业被定义为Node.js函数。

如果可能,我如何定义作业名称,脚本路径和脚本参数?

对于同一任务,是否有比KUE更好的选择。
优选地具有UI和小内存占用。 :)

1 个答案:

答案 0 :(得分:2)

首先,编写节点工作程序以使用Kue作业。示例:worker.js

然后,添加kue代码:

var kue = require('kue')
, queue = kue.createQueue();

将侦听器添加到所需的代码中:

queue.process('MYEXTERNALJOB', function(job, done){
    runJob(job.data, done);
});

尝试child_process.exec

function runJob(data, done){
        //You can use the job's data object to pass your external script parameters
        var a = data.a;
        var b = data.b;
        var c = data.c;
        var yourCode = '/usr/bin/myScript.sh -a ' + a + ' -b ' + b + ' -c ' + c
        var exec = require('child_process').exec,
        child;

        child = exec(yourCode,
            function (error, stdout, stderr) {
                console.log('stdout: ' + stdout);
                console.log('stderr: ' +  stderr);
                if (error !== null) {
                    console.log('exec error: ' + error);
                    done(error); //callback with error for your publisher code
                }else{
                    done(null, stdout); // callback with the results, which you can potentially use on your publisher code
                }
            });
         }
}

然后,记得运行你的工作人员以便它可以轮询Kue工作:

$ node worker.js

现在您只需要在主代码

上为MYEXTERNALJOB创建作业
var kue = require('kue')
, queue = kue.createQueue();

var job = queue.create('MYEXTERNALJOB', {
    a: 10
  , b: 20
  , c: 30
}).save( function(err){
   if( !err ) console.log( job.id );
});

请务必在complete之前为failedfailed attemptsave添加事件处理程序。