mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2025-01-13 21:19:06 +01:00
Fix: Simplify footprint logic, fix aggregated sum values
This commit is contained in:
parent
849b7e038d
commit
60b56bd41a
@ -23,20 +23,8 @@
|
|||||||
: metricConfig.alert,
|
: metricConfig.alert,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (job.exclusive === 1) {
|
// Job_Exclusivity does not matter, only aggregation
|
||||||
// Exclusive: Use as defined
|
if (metricConfig.aggregation === "avg") {
|
||||||
return defaultThresholds;
|
|
||||||
} else {
|
|
||||||
// Shared: Handle specifically
|
|
||||||
if (metricConfig.name === "cpu_load") {
|
|
||||||
// Special: Avg Aggregation BUT scaled based on #hwthreads
|
|
||||||
return {
|
|
||||||
peak: job.numHWThreads,
|
|
||||||
normal: job.numHWThreads,
|
|
||||||
caution: defaultThresholds.caution,
|
|
||||||
alert: defaultThresholds.alert,
|
|
||||||
};
|
|
||||||
} else if (metricConfig.aggregation === "avg") {
|
|
||||||
return defaultThresholds;
|
return defaultThresholds;
|
||||||
} else if (metricConfig.aggregation === "sum") {
|
} else if (metricConfig.aggregation === "sum") {
|
||||||
const jobFraction =
|
const jobFraction =
|
||||||
@ -52,9 +40,8 @@
|
|||||||
"Missing or unkown aggregation mode (sum/avg) for metric:",
|
"Missing or unkown aggregation mode (sum/avg) for metric:",
|
||||||
metricConfig,
|
metricConfig,
|
||||||
);
|
);
|
||||||
return null;
|
return defaultThresholds;
|
||||||
}
|
}
|
||||||
} // Other job.exclusive cases?
|
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
@ -91,29 +78,6 @@
|
|||||||
: ["cpu_load", "flops_any", "mem_used", "mem_bw"]; // Exclusive
|
: ["cpu_load", "flops_any", "mem_used", "mem_bw"]; // Exclusive
|
||||||
|
|
||||||
const footprintData = footprintMetrics.map((fm) => {
|
const footprintData = footprintMetrics.map((fm) => {
|
||||||
// Mean: Primarily use backend sourced avgs from job.*, secondarily calculate/read from metricdata
|
|
||||||
let mv = null;
|
|
||||||
if (fm === "cpu_load" && job.loadAvg !== 0) {
|
|
||||||
mv = round(job.loadAvg, 2);
|
|
||||||
} else if (fm === "flops_any" && job.flopsAnyAvg !== 0) {
|
|
||||||
mv = round(job.flopsAnyAvg, 2);
|
|
||||||
} else if (fm === "mem_bw" && job.memBwAvg !== 0) {
|
|
||||||
mv = round(job.memBwAvg, 2);
|
|
||||||
} else {
|
|
||||||
// Calculate from jobMetrics
|
|
||||||
const jm = jobMetrics.find((jm) => jm.name === fm && jm.scope === "node");
|
|
||||||
if (jm?.metric?.statisticsSeries) {
|
|
||||||
mv = round(mean(jm.metric.statisticsSeries.mean), 2);
|
|
||||||
} else if (jm?.metric?.series?.length > 1) {
|
|
||||||
const avgs = jm.metric.series.map((jms) => jms.statistics.avg);
|
|
||||||
mv = round(mean(avgs), 2);
|
|
||||||
} else if (jm?.metric?.series) {
|
|
||||||
mv = round(jm.metric.series[0].statistics.avg, 2);
|
|
||||||
} else {
|
|
||||||
mv = 0.0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Unit
|
// Unit
|
||||||
const fmc = getContext("metrics")(job.cluster, fm);
|
const fmc = getContext("metrics")(job.cluster, fm);
|
||||||
let unit = "";
|
let unit = "";
|
||||||
@ -123,6 +87,44 @@
|
|||||||
const fmt = findJobThresholds(job, fmc, subclusterConfig);
|
const fmt = findJobThresholds(job, fmc, subclusterConfig);
|
||||||
if (fm === "flops_any") fmt.peak = round(fmt.peak * 0.85, 0);
|
if (fm === "flops_any") fmt.peak = round(fmt.peak * 0.85, 0);
|
||||||
|
|
||||||
|
// Value: Primarily use backend sourced avgs from job.*, secondarily calculate/read from metricdata
|
||||||
|
// Exclusivity does not matter
|
||||||
|
let mv = 0.0;
|
||||||
|
if (fmc.aggregation === "avg") {
|
||||||
|
if (fm === "cpu_load" && job.loadAvg !== 0) {
|
||||||
|
mv = round(job.loadAvg, 2);
|
||||||
|
} else if (fm === "flops_any" && job.flopsAnyAvg !== 0) {
|
||||||
|
mv = round(job.flopsAnyAvg, 2);
|
||||||
|
} else if (fm === "mem_bw" && job.memBwAvg !== 0) {
|
||||||
|
mv = round(job.memBwAvg, 2);
|
||||||
|
} else {
|
||||||
|
// Calculate Avg from jobMetrics
|
||||||
|
const jm = jobMetrics.find((jm) => jm.name === fm && jm.scope === "node");
|
||||||
|
if (jm?.metric?.statisticsSeries) {
|
||||||
|
mv = round(mean(jm.metric.statisticsSeries.mean), 2);
|
||||||
|
} else if (jm?.metric?.series?.length > 1) {
|
||||||
|
const avgs = jm.metric.series.map((jms) => jms.statistics.avg);
|
||||||
|
mv = round(mean(avgs), 2);
|
||||||
|
} else if (jm?.metric?.series) {
|
||||||
|
mv = round(jm.metric.series[0].statistics.avg, 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (fmc.aggregation === "sum") {
|
||||||
|
// Calculate Sum from jobMetrics: Sum all node averages
|
||||||
|
const jm = jobMetrics.find((jm) => jm.name === fm && jm.scope === "node");
|
||||||
|
if (jm?.metric?.series?.length > 1) { // More than 1 node
|
||||||
|
const avgs = jm.metric.series.map((jms) => jms.statistics.avg);
|
||||||
|
mv = round(avgs.reduce((a, b) => a + b, 0));
|
||||||
|
} else if (jm?.metric?.series) {
|
||||||
|
mv = round(jm.metric.series[0].statistics.avg, 2);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.warn(
|
||||||
|
"Missing or unkown aggregation mode (sum/avg) for metric:",
|
||||||
|
metricConfig,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Define basic data
|
// Define basic data
|
||||||
const fmBase = {
|
const fmBase = {
|
||||||
name: fm,
|
name: fm,
|
||||||
|
Loading…
Reference in New Issue
Block a user