Browse Source

Fixes for #504 (#604)

pull/1/head
rozetko 6 years ago committed by GitHub
parent
commit
493bd4dd49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 67
      server/src/controllers/analytics_controller.ts

67
server/src/controllers/analytics_controller.ts

@ -110,24 +110,35 @@ async function runTask(task: AnalyticsTask): Promise<TaskResult> {
}); });
} }
async function query(analyticUnit: AnalyticUnit.AnalyticUnit, detector: AnalyticUnit.DetectorType, range?: any) { async function getQueryRange(
if(range === undefined) { analyticUnitId: AnalyticUnit.AnalyticUnitId,
if(detector === AnalyticUnit.DetectorType.PATTERN) { detectorType: AnalyticUnit.DetectorType
): Promise<{ from: number, to: number }> {
if(detectorType === AnalyticUnit.DetectorType.PATTERN) {
// TODO: find labeled OR deleted segments to generate timerange // TODO: find labeled OR deleted segments to generate timerange
const segments = await Segment.findMany(analyticUnit.id, { labeled: true }); const segments = await Segment.findMany(analyticUnitId, { labeled: true });
if(segments.length === 0) { if(segments.length === 0) {
throw new Error('Need at least 1 labeled segment'); throw new Error('Need at least 1 labeled segment');
} }
range = getQueryRangeForLearningBySegments(segments); return getQueryRangeForLearningBySegments(segments);
} else if(detector === AnalyticUnit.DetectorType.THRESHOLD) { }
if(detectorType === AnalyticUnit.DetectorType.THRESHOLD) {
const now = Date.now(); const now = Date.now();
range = { return {
from: now - 5 * SECONDS_IN_MINUTE * 1000, from: now - 5 * SECONDS_IN_MINUTE * 1000,
to: now to: now
}; };
} }
throw new Error(`Cannot get query range for detector type ${detectorType}`);
} }
async function query(
analyticUnit: AnalyticUnit.AnalyticUnit,
range: { from: number, to: number }
) {
console.log(`query time range: from ${new Date(range.from)} to ${new Date(range.to)}`); console.log(`query time range: from ${new Date(range.from)} to ${new Date(range.to)}`);
const grafanaUrl = getGrafanaUrl(analyticUnit.grafanaUrl); const grafanaUrl = getGrafanaUrl(analyticUnit.grafanaUrl);
@ -219,7 +230,8 @@ export async function runLearning(id: AnalyticUnit.AnalyticUnitId) {
taskPayload.threshold = threshold; taskPayload.threshold = threshold;
} }
taskPayload.data = await query(analyticUnit, detector); const range = await getQueryRange(id, detector);
taskPayload.data = await query(analyticUnit, range);
let task = new AnalyticsTask( let task = new AnalyticsTask(
id, AnalyticsTaskType.LEARN, taskPayload id, AnalyticsTaskType.LEARN, taskPayload
@ -251,8 +263,10 @@ export async function runDetect(id: AnalyticUnit.AnalyticUnitId, from?: number,
let range; let range;
if(from !== undefined && to !== undefined) { if(from !== undefined && to !== undefined) {
range = { from, to }; range = { from, to };
} else {
range = await getQueryRange(id, detector);
} }
const data = await query(unit, detector, range); const data = await query(unit, range);
let oldCache = await AnalyticUnitCache.findById(id); let oldCache = await AnalyticUnitCache.findById(id);
if(oldCache !== null) { if(oldCache !== null) {
@ -268,31 +282,30 @@ export async function runDetect(id: AnalyticUnit.AnalyticUnitId, from?: number,
console.log(`run task, id:${id}`); console.log(`run task, id:${id}`);
// TODO: status: detection // TODO: status: detection
await AnalyticUnit.setStatus(id, AnalyticUnit.AnalyticUnitStatus.LEARNING); await AnalyticUnit.setStatus(id, AnalyticUnit.AnalyticUnitStatus.LEARNING);
let result = await runTask(task); const result = await runTask(task);
if(range !== undefined) {
if( if(result.status === AnalyticUnit.AnalyticUnitStatus.FAILED) {
result.status === AnalyticUnit.AnalyticUnitStatus.SUCCESS ||
result.status === AnalyticUnit.AnalyticUnitStatus.READY
) {
await Detection.insertSpan(
new Detection.DetectionSpan(id, range.from, range.to, Detection.DetectionStatus.READY)
);
} else if (result.status === AnalyticUnit.AnalyticUnitStatus.FAILED) {
await Detection.insertSpan( await Detection.insertSpan(
new Detection.DetectionSpan(id, range.from, range.to, Detection.DetectionStatus.FAILED) new Detection.DetectionSpan(id, range.from, range.to, Detection.DetectionStatus.FAILED)
); );
}
}
if(result.status === AnalyticUnit.AnalyticUnitStatus.FAILED) {
throw new Error(result.error); throw new Error(result.error);
} }
let payload = await processDetectionResult(id, result.payload); const payload = await processDetectionResult(id, result.payload);
const cache = AnalyticUnitCache.AnalyticUnitCache.fromObject({ _id: id, data: payload.cache });
const intersection = cache.getIntersection();
await Detection.insertSpan(
new Detection.DetectionSpan(
id,
range.from + intersection,
range.to - intersection,
Detection.DetectionStatus.READY
)
);
// TODO: uncomment it // TODO: uncomment it
// It clears segments when redetecting on another timerange // It clears segments when redetecting on another timerange
// await deleteNonDetectedSegments(id, payload); // await deleteNonDetectedSegments(id, payload);
await Promise.all([ await Promise.all([
Segment.insertSegments(payload.segments), Segment.insertSegments(payload.segments),
AnalyticUnitCache.setData(id, payload.cache), AnalyticUnitCache.setData(id, payload.cache),
@ -524,13 +537,13 @@ async function runDetectionOnExtendedSpan(
const intersection = analyticUnitCache.getIntersection(); const intersection = analyticUnitCache.getIntersection();
const intersectedFrom = Math.max(from - intersection, 0); const intersectedFrom = Math.max(from - intersection, 0);
const intersectedTo = to + intersection const intersectedTo = to + intersection;
runDetect(analyticUnitId, intersectedFrom, intersectedTo); runDetect(analyticUnitId, intersectedFrom, intersectedTo);
const detection = new Detection.DetectionSpan( const detection = new Detection.DetectionSpan(
analyticUnitId, analyticUnitId,
intersectedFrom, from,
intersectedTo, to,
Detection.DetectionStatus.RUNNING Detection.DetectionStatus.RUNNING
); );
await Detection.insertSpan(detection); await Detection.insertSpan(detection);

Loading…
Cancel
Save