2016-04-14 23:09:07 +08:00
|
|
|
var camshaft = require('camshaft');
|
2016-09-23 23:11:04 +08:00
|
|
|
var fs = require('fs');
|
2016-04-14 23:09:07 +08:00
|
|
|
|
2016-10-11 21:46:11 +08:00
|
|
|
var REDIS_LIMITS = {
|
|
|
|
DB: 5,
|
|
|
|
PREFIX: 'limits:analyses:' // + username
|
|
|
|
};
|
|
|
|
|
|
|
|
function AnalysisBackend (metadataBackend, options) {
|
|
|
|
this.metadataBackend = metadataBackend;
|
2016-09-23 23:11:04 +08:00
|
|
|
options = options || {};
|
|
|
|
this.setBatchConfig(options.batch);
|
|
|
|
this.setLoggerConfig(options.logger);
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = AnalysisBackend;
|
|
|
|
|
|
|
|
AnalysisBackend.prototype.setBatchConfig = function (options) {
|
|
|
|
var batchConfig = options || {};
|
2016-04-14 23:25:08 +08:00
|
|
|
batchConfig.endpoint = batchConfig.endpoint || 'http://127.0.0.1:8080/api/v1/sql/job';
|
|
|
|
batchConfig.inlineExecution = batchConfig.inlineExecution || false;
|
2016-04-20 22:36:29 +08:00
|
|
|
batchConfig.hostHeaderTemplate = batchConfig.hostHeaderTemplate || '{{=it.username}}.localhost.lan';
|
2016-04-14 23:25:08 +08:00
|
|
|
this.batchConfig = batchConfig;
|
2016-09-23 23:11:04 +08:00
|
|
|
};
|
2016-04-14 23:09:07 +08:00
|
|
|
|
2016-09-23 23:11:04 +08:00
|
|
|
AnalysisBackend.prototype.setLoggerConfig = function (options) {
|
2016-10-11 22:01:43 +08:00
|
|
|
this.loggerConfig = options || {};
|
2016-09-26 23:39:27 +08:00
|
|
|
|
|
|
|
if (this.loggerConfig.filename) {
|
|
|
|
this.stream = fs.createWriteStream(this.loggerConfig.filename, { flags: 'a', encoding: 'utf8' });
|
|
|
|
|
|
|
|
process.on('SIGHUP', function () {
|
|
|
|
if (this.stream) {
|
|
|
|
this.stream.destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.stream = fs.createWriteStream(this.loggerConfig.filename, { flags: 'a', encoding: 'utf8' });
|
|
|
|
}.bind(this));
|
|
|
|
}
|
2016-09-23 23:11:04 +08:00
|
|
|
};
|
2016-04-14 23:09:07 +08:00
|
|
|
|
|
|
|
AnalysisBackend.prototype.create = function(analysisConfiguration, analysisDefinition, callback) {
|
2016-04-14 23:25:08 +08:00
|
|
|
analysisConfiguration.batch.endpoint = this.batchConfig.endpoint;
|
|
|
|
analysisConfiguration.batch.inlineExecution = this.batchConfig.inlineExecution;
|
2016-04-20 22:36:29 +08:00
|
|
|
analysisConfiguration.batch.hostHeaderTemplate = this.batchConfig.hostHeaderTemplate;
|
2016-09-26 23:39:27 +08:00
|
|
|
|
2016-09-23 23:11:04 +08:00
|
|
|
analysisConfiguration.logger = {
|
2016-09-26 23:39:27 +08:00
|
|
|
stream: this.stream ? this.stream : process.stdout
|
2016-09-23 23:11:04 +08:00
|
|
|
};
|
2016-04-14 23:25:08 +08:00
|
|
|
|
2016-10-11 21:46:11 +08:00
|
|
|
this.getAnalysesLimits(analysisConfiguration.user, function(err, limits) {
|
|
|
|
analysisConfiguration.limits = limits || {};
|
|
|
|
camshaft.create(analysisConfiguration, analysisDefinition, callback);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
AnalysisBackend.prototype.getAnalysesLimits = function(username, callback) {
|
|
|
|
var analysesLimitsKey = REDIS_LIMITS.PREFIX + username;
|
|
|
|
this.metadataBackend.redisCmd(REDIS_LIMITS.DB, 'HGETALL', [analysesLimitsKey], function(err, analysesTimeouts) {
|
|
|
|
analysesTimeouts = analysesTimeouts || {};
|
|
|
|
|
|
|
|
var analysesLimits = {
|
|
|
|
analyses: {
|
|
|
|
// buffer: {
|
|
|
|
// timeout: 1000
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Object.keys(analysesTimeouts).forEach(function(analysisType) {
|
|
|
|
analysesLimits.analyses[analysisType] = {
|
|
|
|
timeout: Number.isFinite(+analysesTimeouts[analysisType]) ? +analysesTimeouts[analysisType] : 0
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
return callback(null, analysesLimits);
|
|
|
|
});
|
2016-04-14 23:09:07 +08:00
|
|
|
};
|