在KUE https://github.com/LearnBoost/kue中,是否可以将脚本作为作业进行队列和执行?
像/usr/bin/myScript.sh -a 10 -b 20 -c 30这样的脚本
我看到的所有示例都假设作业被定义为Node.js函数。
如果可能的话,我如何定义作业名称、脚本路径和脚本参数?
对于同样的任务,还有比KUE更好的选择吗?
最好有UI和较小的内存占用。:)
发布于 2015-06-24 03:58:56
首先,编写一个节点工作者来使用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、failed和failed attempt之前为save添加事件处理程序。
https://stackoverflow.com/questions/26479892
复制相似问题