@emmvish/stable-request 2.8.4 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +1153 -2319
- package/dist/constants/index.d.ts +0 -10
- package/dist/constants/index.d.ts.map +1 -1
- package/dist/constants/index.js +0 -113
- package/dist/constants/index.js.map +1 -1
- package/dist/core/index.d.ts +0 -5
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +0 -5
- package/dist/core/index.js.map +1 -1
- package/dist/core/stable-request.d.ts.map +1 -1
- package/dist/core/stable-request.js +22 -7
- package/dist/core/stable-request.js.map +1 -1
- package/dist/enums/index.d.ts +0 -37
- package/dist/enums/index.d.ts.map +1 -1
- package/dist/enums/index.js +0 -43
- package/dist/enums/index.js.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +18 -3
- package/dist/index.js.map +1 -1
- package/dist/types/index.d.ts +100 -1135
- package/dist/types/index.d.ts.map +1 -1
- package/dist/utilities/index.d.ts +0 -18
- package/dist/utilities/index.d.ts.map +1 -1
- package/dist/utilities/index.js +0 -18
- package/dist/utilities/index.js.map +1 -1
- package/dist/utilities/infrastructure-persistence.d.ts +0 -1
- package/dist/utilities/infrastructure-persistence.d.ts.map +1 -1
- package/dist/utilities/infrastructure-persistence.js +12 -15
- package/dist/utilities/infrastructure-persistence.js.map +1 -1
- package/dist/utilities/metrics-aggregator.d.ts +2 -13
- package/dist/utilities/metrics-aggregator.d.ts.map +1 -1
- package/dist/utilities/metrics-aggregator.js +9 -251
- package/dist/utilities/metrics-aggregator.js.map +1 -1
- package/dist/utilities/metrics-validator.d.ts +6 -76
- package/dist/utilities/metrics-validator.d.ts.map +1 -1
- package/dist/utilities/metrics-validator.js +12 -181
- package/dist/utilities/metrics-validator.js.map +1 -1
- package/dist/utilities/validate-trial-mode-probabilities.js +2 -2
- package/dist/utilities/validate-trial-mode-probabilities.js.map +1 -1
- package/package.json +20 -24
- package/dist/core/stable-api-gateway.d.ts +0 -4
- package/dist/core/stable-api-gateway.d.ts.map +0 -1
- package/dist/core/stable-api-gateway.js +0 -136
- package/dist/core/stable-api-gateway.js.map +0 -1
- package/dist/core/stable-function.d.ts +0 -11
- package/dist/core/stable-function.d.ts.map +0 -1
- package/dist/core/stable-function.js +0 -340
- package/dist/core/stable-function.js.map +0 -1
- package/dist/core/stable-scheduler.d.ts +0 -71
- package/dist/core/stable-scheduler.d.ts.map +0 -1
- package/dist/core/stable-scheduler.js +0 -768
- package/dist/core/stable-scheduler.js.map +0 -1
- package/dist/core/stable-workflow-graph.d.ts +0 -3
- package/dist/core/stable-workflow-graph.d.ts.map +0 -1
- package/dist/core/stable-workflow-graph.js +0 -5
- package/dist/core/stable-workflow-graph.js.map +0 -1
- package/dist/core/stable-workflow.d.ts +0 -3
- package/dist/core/stable-workflow.d.ts.map +0 -1
- package/dist/core/stable-workflow.js +0 -362
- package/dist/core/stable-workflow.js.map +0 -1
- package/dist/stable-runner/index.d.ts +0 -2
- package/dist/stable-runner/index.d.ts.map +0 -1
- package/dist/stable-runner/index.js +0 -324
- package/dist/stable-runner/index.js.map +0 -1
- package/dist/utilities/concurrency-limiter.d.ts +0 -46
- package/dist/utilities/concurrency-limiter.d.ts.map +0 -1
- package/dist/utilities/concurrency-limiter.js +0 -172
- package/dist/utilities/concurrency-limiter.js.map +0 -1
- package/dist/utilities/execute-branch-workflow.d.ts +0 -3
- package/dist/utilities/execute-branch-workflow.d.ts.map +0 -1
- package/dist/utilities/execute-branch-workflow.js +0 -730
- package/dist/utilities/execute-branch-workflow.js.map +0 -1
- package/dist/utilities/execute-concurrently.d.ts +0 -3
- package/dist/utilities/execute-concurrently.d.ts.map +0 -1
- package/dist/utilities/execute-concurrently.js +0 -258
- package/dist/utilities/execute-concurrently.js.map +0 -1
- package/dist/utilities/execute-gateway-item.d.ts +0 -6
- package/dist/utilities/execute-gateway-item.d.ts.map +0 -1
- package/dist/utilities/execute-gateway-item.js +0 -127
- package/dist/utilities/execute-gateway-item.js.map +0 -1
- package/dist/utilities/execute-non-linear-workflow.d.ts +0 -3
- package/dist/utilities/execute-non-linear-workflow.d.ts.map +0 -1
- package/dist/utilities/execute-non-linear-workflow.js +0 -483
- package/dist/utilities/execute-non-linear-workflow.js.map +0 -1
- package/dist/utilities/execute-phase.d.ts +0 -3
- package/dist/utilities/execute-phase.d.ts.map +0 -1
- package/dist/utilities/execute-phase.js +0 -129
- package/dist/utilities/execute-phase.js.map +0 -1
- package/dist/utilities/execute-sequentially.d.ts +0 -3
- package/dist/utilities/execute-sequentially.d.ts.map +0 -1
- package/dist/utilities/execute-sequentially.js +0 -49
- package/dist/utilities/execute-sequentially.js.map +0 -1
- package/dist/utilities/execute-with-timeout.d.ts +0 -6
- package/dist/utilities/execute-with-timeout.d.ts.map +0 -1
- package/dist/utilities/execute-with-timeout.js +0 -28
- package/dist/utilities/execute-with-timeout.js.map +0 -1
- package/dist/utilities/execute-workflow-graph.d.ts +0 -3
- package/dist/utilities/execute-workflow-graph.d.ts.map +0 -1
- package/dist/utilities/execute-workflow-graph.js +0 -429
- package/dist/utilities/execute-workflow-graph.js.map +0 -1
- package/dist/utilities/extract-common-request-config-options.d.ts +0 -3
- package/dist/utilities/extract-common-request-config-options.d.ts.map +0 -1
- package/dist/utilities/extract-common-request-config-options.js +0 -12
- package/dist/utilities/extract-common-request-config-options.js.map +0 -1
- package/dist/utilities/fn-exec.d.ts +0 -3
- package/dist/utilities/fn-exec.d.ts.map +0 -1
- package/dist/utilities/fn-exec.js +0 -66
- package/dist/utilities/fn-exec.js.map +0 -1
- package/dist/utilities/function-cache-manager.d.ts +0 -32
- package/dist/utilities/function-cache-manager.d.ts.map +0 -1
- package/dist/utilities/function-cache-manager.js +0 -172
- package/dist/utilities/function-cache-manager.js.map +0 -1
- package/dist/utilities/prepare-api-function-options.d.ts +0 -3
- package/dist/utilities/prepare-api-function-options.d.ts.map +0 -1
- package/dist/utilities/prepare-api-function-options.js +0 -51
- package/dist/utilities/prepare-api-function-options.js.map +0 -1
- package/dist/utilities/prepare-api-request-data.d.ts +0 -3
- package/dist/utilities/prepare-api-request-data.d.ts.map +0 -1
- package/dist/utilities/prepare-api-request-data.js +0 -15
- package/dist/utilities/prepare-api-request-data.js.map +0 -1
- package/dist/utilities/prepare-api-request-options.d.ts +0 -3
- package/dist/utilities/prepare-api-request-options.d.ts.map +0 -1
- package/dist/utilities/prepare-api-request-options.js +0 -22
- package/dist/utilities/prepare-api-request-options.js.map +0 -1
- package/dist/utilities/rate-limiter.d.ts +0 -49
- package/dist/utilities/rate-limiter.d.ts.map +0 -1
- package/dist/utilities/rate-limiter.js +0 -197
- package/dist/utilities/rate-limiter.js.map +0 -1
- package/dist/utilities/validate-workflow-graph.d.ts +0 -7
- package/dist/utilities/validate-workflow-graph.d.ts.map +0 -1
- package/dist/utilities/validate-workflow-graph.js +0 -235
- package/dist/utilities/validate-workflow-graph.js.map +0 -1
- package/dist/utilities/workflow-graph-builder.d.ts +0 -37
- package/dist/utilities/workflow-graph-builder.d.ts.map +0 -1
- package/dist/utilities/workflow-graph-builder.js +0 -225
- package/dist/utilities/workflow-graph-builder.js.map +0 -1
|
@@ -1,179 +1,32 @@
|
|
|
1
1
|
export class MetricsAggregator {
|
|
2
|
-
static extractWorkflowMetrics(result) {
|
|
3
|
-
const skippedPhases = result.phases.filter(p => p.skipped).length;
|
|
4
|
-
const failedPhases = result.phases.filter(p => !p.success && !p.skipped).length;
|
|
5
|
-
const phaseReplays = result.executionHistory.filter((record, index, arr) => arr.filter(r => r.phaseId === record.phaseId).length > 1).length;
|
|
6
|
-
const throughput = result.executionTime > 0
|
|
7
|
-
? (result.totalRequests / (result.executionTime / 1000))
|
|
8
|
-
: 0;
|
|
9
|
-
const metrics = {
|
|
10
|
-
workflowId: result.workflowId,
|
|
11
|
-
success: result.success,
|
|
12
|
-
executionTime: result.executionTime,
|
|
13
|
-
timestamp: result.timestamp,
|
|
14
|
-
totalPhases: result.totalPhases,
|
|
15
|
-
completedPhases: result.completedPhases,
|
|
16
|
-
skippedPhases: skippedPhases,
|
|
17
|
-
failedPhases: failedPhases,
|
|
18
|
-
phaseCompletionRate: result.totalPhases > 0
|
|
19
|
-
? (result.completedPhases / result.totalPhases) * 100
|
|
20
|
-
: 0,
|
|
21
|
-
averagePhaseExecutionTime: result.phases.length > 0
|
|
22
|
-
? result.phases.reduce((sum, p) => sum + p.executionTime, 0) / result.phases.length
|
|
23
|
-
: 0,
|
|
24
|
-
totalRequests: result.totalRequests,
|
|
25
|
-
successfulRequests: result.successfulRequests,
|
|
26
|
-
failedRequests: result.failedRequests,
|
|
27
|
-
requestSuccessRate: result.totalRequests > 0
|
|
28
|
-
? (result.successfulRequests / result.totalRequests) * 100
|
|
29
|
-
: 0,
|
|
30
|
-
requestFailureRate: result.totalRequests > 0
|
|
31
|
-
? (result.failedRequests / result.totalRequests) * 100
|
|
32
|
-
: 0,
|
|
33
|
-
terminatedEarly: result.terminatedEarly || false,
|
|
34
|
-
terminationReason: result.terminationReason,
|
|
35
|
-
totalPhaseReplays: phaseReplays,
|
|
36
|
-
totalPhaseSkips: skippedPhases,
|
|
37
|
-
throughput: throughput
|
|
38
|
-
};
|
|
39
|
-
if (result.branches && result.branches.length > 0) {
|
|
40
|
-
const completedBranches = result.branches.filter(b => !b.skipped && b.success).length;
|
|
41
|
-
const failedBranches = result.branches.filter(b => !b.success && !b.skipped).length;
|
|
42
|
-
metrics.totalBranches = result.branches.length;
|
|
43
|
-
metrics.completedBranches = completedBranches;
|
|
44
|
-
metrics.failedBranches = failedBranches;
|
|
45
|
-
metrics.branchSuccessRate = result.branches.length > 0
|
|
46
|
-
? (completedBranches / result.branches.length) * 100
|
|
47
|
-
: 0;
|
|
48
|
-
}
|
|
49
|
-
return metrics;
|
|
50
|
-
}
|
|
51
|
-
static extractBranchMetrics(branch) {
|
|
52
|
-
const failedPhases = branch.phaseResults.filter(p => !p.success && !p.skipped).length;
|
|
53
|
-
const totalRequests = branch.phaseResults.reduce((sum, p) => sum + p.totalRequests, 0);
|
|
54
|
-
const successfulRequests = branch.phaseResults.reduce((sum, p) => sum + p.successfulRequests, 0);
|
|
55
|
-
const failedRequests = branch.phaseResults.reduce((sum, p) => sum + p.failedRequests, 0);
|
|
56
|
-
return {
|
|
57
|
-
branchId: branch.branchId,
|
|
58
|
-
branchIndex: branch.branchIndex,
|
|
59
|
-
executionNumber: branch.executionNumber,
|
|
60
|
-
success: branch.success,
|
|
61
|
-
executionTime: branch.executionTime,
|
|
62
|
-
skipped: branch.skipped || false,
|
|
63
|
-
totalPhases: branch.phaseResults.length,
|
|
64
|
-
completedPhases: branch.completedPhases,
|
|
65
|
-
failedPhases: failedPhases,
|
|
66
|
-
phaseCompletionRate: branch.phaseResults.length > 0
|
|
67
|
-
? (branch.completedPhases / branch.phaseResults.length) * 100
|
|
68
|
-
: 0,
|
|
69
|
-
totalRequests: totalRequests,
|
|
70
|
-
successfulRequests: successfulRequests,
|
|
71
|
-
failedRequests: failedRequests,
|
|
72
|
-
requestSuccessRate: totalRequests > 0
|
|
73
|
-
? (successfulRequests / totalRequests) * 100
|
|
74
|
-
: 0,
|
|
75
|
-
hasDecision: !!branch.decision,
|
|
76
|
-
decisionAction: branch.decision?.action,
|
|
77
|
-
error: branch.error
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
static extractPhaseMetrics(phase) {
|
|
81
|
-
return {
|
|
82
|
-
phaseId: phase.phaseId,
|
|
83
|
-
phaseIndex: phase.phaseIndex,
|
|
84
|
-
workflowId: phase.workflowId,
|
|
85
|
-
branchId: phase.branchId,
|
|
86
|
-
executionNumber: phase.executionNumber || 0,
|
|
87
|
-
success: phase.success,
|
|
88
|
-
skipped: phase.skipped || false,
|
|
89
|
-
executionTime: phase.executionTime,
|
|
90
|
-
timestamp: phase.timestamp,
|
|
91
|
-
totalRequests: phase.totalRequests,
|
|
92
|
-
successfulRequests: phase.successfulRequests,
|
|
93
|
-
failedRequests: phase.failedRequests,
|
|
94
|
-
requestSuccessRate: phase.totalRequests > 0
|
|
95
|
-
? (phase.successfulRequests / phase.totalRequests) * 100
|
|
96
|
-
: 0,
|
|
97
|
-
requestFailureRate: phase.totalRequests > 0
|
|
98
|
-
? (phase.failedRequests / phase.totalRequests) * 100
|
|
99
|
-
: 0,
|
|
100
|
-
hasDecision: !!phase.decision,
|
|
101
|
-
decisionAction: phase.decision?.action,
|
|
102
|
-
targetPhaseId: phase.decision?.targetPhaseId,
|
|
103
|
-
replayCount: phase.decision?.replayCount,
|
|
104
|
-
error: phase.error
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
static extractRequestGroupMetrics(responses) {
|
|
108
|
-
const groupMap = new Map();
|
|
109
|
-
responses.forEach(response => {
|
|
110
|
-
const groupId = response.groupId || 'default';
|
|
111
|
-
if (!groupMap.has(groupId)) {
|
|
112
|
-
groupMap.set(groupId, []);
|
|
113
|
-
}
|
|
114
|
-
groupMap.get(groupId).push(response);
|
|
115
|
-
});
|
|
116
|
-
return Array.from(groupMap.entries()).map(([groupId, groupResponses]) => {
|
|
117
|
-
const successfulRequests = groupResponses.filter(r => r.success).length;
|
|
118
|
-
const failedRequests = groupResponses.filter(r => !r.success).length;
|
|
119
|
-
const totalRequests = groupResponses.length;
|
|
120
|
-
return {
|
|
121
|
-
groupId,
|
|
122
|
-
totalRequests,
|
|
123
|
-
successfulRequests,
|
|
124
|
-
failedRequests,
|
|
125
|
-
successRate: totalRequests > 0 ? (successfulRequests / totalRequests) * 100 : 0,
|
|
126
|
-
failureRate: totalRequests > 0 ? (failedRequests / totalRequests) * 100 : 0,
|
|
127
|
-
requestIds: groupResponses.map(r => r.requestId)
|
|
128
|
-
};
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
static extractRequestMetrics(responses) {
|
|
132
|
-
return responses.map(response => ({
|
|
133
|
-
requestId: response.requestId,
|
|
134
|
-
groupId: response.groupId,
|
|
135
|
-
success: response.success,
|
|
136
|
-
hasError: !!response.error,
|
|
137
|
-
errorMessage: response.error
|
|
138
|
-
}));
|
|
139
|
-
}
|
|
140
2
|
static extractCircuitBreakerMetrics(circuitBreaker) {
|
|
141
3
|
const state = circuitBreaker.getState();
|
|
142
4
|
const now = Date.now();
|
|
143
|
-
const timeSinceLastStateChange = now - state.lastStateChangeTime;
|
|
144
|
-
const timeUntilRecovery = state.openUntil ? Math.max(0, state.openUntil - now) : null;
|
|
145
5
|
return {
|
|
146
6
|
state: state.state,
|
|
147
|
-
isHealthy: state.state
|
|
7
|
+
isHealthy: state.state === 'CLOSED',
|
|
148
8
|
totalRequests: state.totalRequests,
|
|
149
9
|
successfulRequests: state.successfulRequests,
|
|
150
10
|
failedRequests: state.failedRequests,
|
|
151
11
|
failurePercentage: state.failurePercentage,
|
|
152
12
|
stateTransitions: state.stateTransitions,
|
|
153
13
|
lastStateChangeTime: state.lastStateChangeTime,
|
|
154
|
-
timeSinceLastStateChange:
|
|
14
|
+
timeSinceLastStateChange: now - state.lastStateChangeTime,
|
|
155
15
|
openCount: state.openCount,
|
|
156
16
|
totalOpenDuration: state.totalOpenDuration,
|
|
157
17
|
averageOpenDuration: state.averageOpenDuration,
|
|
158
18
|
isCurrentlyOpen: state.state === 'OPEN',
|
|
159
19
|
openUntil: state.openUntil,
|
|
160
|
-
timeUntilRecovery:
|
|
20
|
+
timeUntilRecovery: state.openUntil ? Math.max(0, state.openUntil - now) : null,
|
|
161
21
|
recoveryAttempts: state.recoveryAttempts,
|
|
162
22
|
successfulRecoveries: state.successfulRecoveries,
|
|
163
23
|
failedRecoveries: state.failedRecoveries,
|
|
164
24
|
recoverySuccessRate: state.recoverySuccessRate,
|
|
165
|
-
config:
|
|
166
|
-
failureThresholdPercentage: state.config.failureThresholdPercentage,
|
|
167
|
-
minimumRequests: state.config.minimumRequests,
|
|
168
|
-
recoveryTimeoutMs: state.config.recoveryTimeoutMs,
|
|
169
|
-
successThresholdPercentage: state.config.successThresholdPercentage,
|
|
170
|
-
halfOpenMaxRequests: state.config.halfOpenMaxRequests,
|
|
171
|
-
trackIndividualAttempts: state.config.trackIndividualAttempts
|
|
172
|
-
}
|
|
25
|
+
config: state.config
|
|
173
26
|
};
|
|
174
27
|
}
|
|
175
|
-
static extractCacheMetrics(
|
|
176
|
-
const stats =
|
|
28
|
+
static extractCacheMetrics(cacheManager) {
|
|
29
|
+
const stats = cacheManager.getStats();
|
|
177
30
|
const now = Date.now();
|
|
178
31
|
return {
|
|
179
32
|
isEnabled: true,
|
|
@@ -196,105 +49,10 @@ export class MetricsAggregator {
|
|
|
196
49
|
oldestEntryAge: stats.oldestEntry ? now - stats.oldestEntry : null,
|
|
197
50
|
newestEntryAge: stats.newestEntry ? now - stats.newestEntry : null,
|
|
198
51
|
networkRequestsSaved: stats.hits,
|
|
199
|
-
cacheEfficiency: stats.
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
static extractFunctionCacheMetrics(cache) {
|
|
203
|
-
const stats = cache.getStats();
|
|
204
|
-
return {
|
|
205
|
-
isEnabled: true,
|
|
206
|
-
currentSize: stats.size,
|
|
207
|
-
maxSize: stats.maxSize,
|
|
208
|
-
validEntries: stats.size,
|
|
209
|
-
expiredEntries: 0,
|
|
210
|
-
utilizationPercentage: (stats.size / stats.maxSize) * 100,
|
|
211
|
-
totalRequests: stats.hits + stats.misses,
|
|
212
|
-
hits: stats.hits,
|
|
213
|
-
misses: stats.misses,
|
|
214
|
-
hitRate: stats.hitRate,
|
|
215
|
-
missRate: stats.missRate,
|
|
216
|
-
sets: stats.sets,
|
|
217
|
-
evictions: stats.evictions,
|
|
218
|
-
expirations: 0,
|
|
219
|
-
averageGetTime: stats.averageGetTime,
|
|
220
|
-
averageSetTime: stats.averageSetTime,
|
|
221
|
-
averageCacheAge: 0,
|
|
222
|
-
oldestEntryAge: null,
|
|
223
|
-
newestEntryAge: null,
|
|
224
|
-
networkRequestsSaved: stats.hits,
|
|
225
|
-
cacheEfficiency: stats.hitRate
|
|
226
|
-
};
|
|
227
|
-
}
|
|
228
|
-
static extractRateLimiterMetrics(rateLimiter) {
|
|
229
|
-
const state = rateLimiter.getState();
|
|
230
|
-
const averageRequestRate = state.completedRequests > 0
|
|
231
|
-
? state.totalRequests / (state.windowMs / 1000)
|
|
232
|
-
: 0;
|
|
233
|
-
return {
|
|
234
|
-
maxRequests: state.maxRequests,
|
|
235
|
-
windowMs: state.windowMs,
|
|
236
|
-
availableTokens: state.availableTokens,
|
|
237
|
-
queueLength: state.queueLength,
|
|
238
|
-
requestsInCurrentWindow: state.requestsInCurrentWindow,
|
|
239
|
-
totalRequests: state.totalRequests,
|
|
240
|
-
completedRequests: state.completedRequests,
|
|
241
|
-
throttledRequests: state.throttledRequests,
|
|
242
|
-
throttleRate: state.throttleRate,
|
|
243
|
-
currentRequestRate: state.currentRequestRate,
|
|
244
|
-
peakRequestRate: state.peakRequestRate,
|
|
245
|
-
averageRequestRate: averageRequestRate,
|
|
246
|
-
peakQueueLength: state.peakQueueLength,
|
|
247
|
-
averageQueueWaitTime: state.averageQueueWaitTime,
|
|
248
|
-
isThrottling: state.queueLength > 0 || state.availableTokens === 0,
|
|
249
|
-
utilizationPercentage: (state.requestsInCurrentWindow / state.maxRequests) * 100
|
|
250
|
-
};
|
|
251
|
-
}
|
|
252
|
-
static extractConcurrencyLimiterMetrics(concurrencyLimiter) {
|
|
253
|
-
const state = concurrencyLimiter.getState();
|
|
254
|
-
return {
|
|
255
|
-
limit: state.limit,
|
|
256
|
-
running: state.running,
|
|
257
|
-
queueLength: state.queueLength,
|
|
258
|
-
utilizationPercentage: state.utilizationPercentage,
|
|
259
|
-
totalRequests: state.totalRequests,
|
|
260
|
-
completedRequests: state.completedRequests,
|
|
261
|
-
failedRequests: state.failedRequests,
|
|
262
|
-
queuedRequests: state.queuedRequests,
|
|
263
|
-
successRate: state.successRate,
|
|
264
|
-
peakConcurrency: state.peakConcurrency,
|
|
265
|
-
averageConcurrency: state.running,
|
|
266
|
-
concurrencyUtilization: state.utilizationPercentage,
|
|
267
|
-
peakQueueLength: state.peakQueueLength,
|
|
268
|
-
averageQueueWaitTime: state.averageQueueWaitTime,
|
|
269
|
-
averageExecutionTime: state.averageExecutionTime,
|
|
270
|
-
isAtCapacity: state.running >= state.limit,
|
|
271
|
-
hasQueuedRequests: state.queueLength > 0
|
|
272
|
-
};
|
|
273
|
-
}
|
|
274
|
-
static aggregateSystemMetrics(workflowResult, circuitBreaker, cache, rateLimiter, concurrencyLimiter) {
|
|
275
|
-
const allResponses = workflowResult.phases.flatMap(phase => phase.responses);
|
|
276
|
-
const metrics = {
|
|
277
|
-
workflow: this.extractWorkflowMetrics(workflowResult),
|
|
278
|
-
branches: workflowResult.branches
|
|
279
|
-
? workflowResult.branches.map(b => this.extractBranchMetrics(b))
|
|
280
|
-
: [],
|
|
281
|
-
phases: workflowResult.phases.map(p => this.extractPhaseMetrics(p)),
|
|
282
|
-
requestGroups: this.extractRequestGroupMetrics(allResponses),
|
|
283
|
-
requests: this.extractRequestMetrics(allResponses)
|
|
52
|
+
cacheEfficiency: stats.totalRequests > 0
|
|
53
|
+
? ((stats.hits / stats.totalRequests) * 100)
|
|
54
|
+
: 0
|
|
284
55
|
};
|
|
285
|
-
if (circuitBreaker) {
|
|
286
|
-
metrics.circuitBreaker = this.extractCircuitBreakerMetrics(circuitBreaker);
|
|
287
|
-
}
|
|
288
|
-
if (cache) {
|
|
289
|
-
metrics.cache = this.extractCacheMetrics(cache);
|
|
290
|
-
}
|
|
291
|
-
if (rateLimiter) {
|
|
292
|
-
metrics.rateLimiter = this.extractRateLimiterMetrics(rateLimiter);
|
|
293
|
-
}
|
|
294
|
-
if (concurrencyLimiter) {
|
|
295
|
-
metrics.concurrencyLimiter = this.extractConcurrencyLimiterMetrics(concurrencyLimiter);
|
|
296
|
-
}
|
|
297
|
-
return metrics;
|
|
298
56
|
}
|
|
299
57
|
}
|
|
300
58
|
//# sourceMappingURL=metrics-aggregator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics-aggregator.js","sourceRoot":"","sources":["../../src/utilities/metrics-aggregator.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"metrics-aggregator.js","sourceRoot":"","sources":["../../src/utilities/metrics-aggregator.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,86 +9,16 @@ export declare class MetricsValidator {
|
|
|
9
9
|
totalExecutionTime?: number;
|
|
10
10
|
averageAttemptTime?: number;
|
|
11
11
|
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
12
|
-
static
|
|
13
|
-
totalRequests?: number;
|
|
14
|
-
successfulRequests?: number;
|
|
15
|
-
failedRequests?: number;
|
|
16
|
-
successRate?: number;
|
|
12
|
+
static validateCircuitBreakerMetrics(metrics: {
|
|
17
13
|
failureRate?: number;
|
|
18
|
-
executionTime?: number;
|
|
19
|
-
throughput?: number;
|
|
20
|
-
averageRequestDuration?: number;
|
|
21
|
-
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
22
|
-
static validateWorkflowMetrics(metrics: {
|
|
23
|
-
totalPhases?: number;
|
|
24
|
-
completedPhases?: number;
|
|
25
|
-
failedPhases?: number;
|
|
26
|
-
totalRequests?: number;
|
|
27
|
-
successfulRequests?: number;
|
|
28
|
-
failedRequests?: number;
|
|
29
|
-
requestSuccessRate?: number;
|
|
30
|
-
requestFailureRate?: number;
|
|
31
|
-
executionTime?: number;
|
|
32
|
-
averagePhaseExecutionTime?: number;
|
|
33
|
-
throughput?: number;
|
|
34
|
-
phaseCompletionRate?: number;
|
|
35
|
-
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
36
|
-
static validatePhaseMetrics(metrics: {
|
|
37
14
|
totalRequests?: number;
|
|
38
|
-
successfulRequests?: number;
|
|
39
15
|
failedRequests?: number;
|
|
40
|
-
requestSuccessRate?: number;
|
|
41
|
-
requestFailureRate?: number;
|
|
42
|
-
executionTime?: number;
|
|
43
16
|
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
44
|
-
static
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
totalRequests?: number;
|
|
50
|
-
successfulRequests?: number;
|
|
51
|
-
failedRequests?: number;
|
|
52
|
-
requestSuccessRate?: number;
|
|
53
|
-
executionTime?: number;
|
|
54
|
-
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
55
|
-
static validateInfrastructureMetrics(infrastructureMetrics: {
|
|
56
|
-
circuitBreaker?: {
|
|
57
|
-
failureRate?: number;
|
|
58
|
-
totalRequests?: number;
|
|
59
|
-
failedRequests?: number;
|
|
60
|
-
};
|
|
61
|
-
cache?: {
|
|
62
|
-
hitRate?: number;
|
|
63
|
-
missRate?: number;
|
|
64
|
-
utilizationPercentage?: number;
|
|
65
|
-
evictionRate?: number;
|
|
66
|
-
};
|
|
67
|
-
rateLimiter?: {
|
|
68
|
-
throttleRate?: number;
|
|
69
|
-
queueLength?: number;
|
|
70
|
-
utilizationPercentage?: number;
|
|
71
|
-
averageQueueWaitTime?: number;
|
|
72
|
-
};
|
|
73
|
-
concurrencyLimiter?: {
|
|
74
|
-
utilizationPercentage?: number;
|
|
75
|
-
queueLength?: number;
|
|
76
|
-
averageQueueWaitTime?: number;
|
|
77
|
-
};
|
|
78
|
-
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
79
|
-
static validateSchedulerMetrics(metrics: {
|
|
80
|
-
totalJobs?: number;
|
|
81
|
-
queued?: number;
|
|
82
|
-
running?: number;
|
|
83
|
-
completed?: number;
|
|
84
|
-
failed?: number;
|
|
85
|
-
dropped?: number;
|
|
86
|
-
totalRuns?: number;
|
|
87
|
-
successRate?: number;
|
|
88
|
-
failureRate?: number;
|
|
89
|
-
throughput?: number;
|
|
90
|
-
averageExecutionTime?: number;
|
|
91
|
-
averageQueueDelay?: number;
|
|
17
|
+
static validateCacheMetrics(metrics: {
|
|
18
|
+
hitRate?: number;
|
|
19
|
+
missRate?: number;
|
|
20
|
+
utilizationPercentage?: number;
|
|
21
|
+
evictionRate?: number;
|
|
92
22
|
}, guardrails: MetricsGuardrails): MetricsValidationResult;
|
|
93
23
|
static validateStableBufferMetrics(metrics: {
|
|
94
24
|
totalTransactions?: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics-validator.d.ts","sourceRoot":"","sources":["../../src/utilities/metrics-validator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,iBAAiB,EAEjB,uBAAuB,EACxB,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"metrics-validator.d.ts","sourceRoot":"","sources":["../../src/utilities/metrics-validator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,iBAAiB,EAEjB,uBAAuB,EACxB,MAAM,mBAAmB,CAAC;AAS3B,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAC,cAAc;IA8C7B,OAAO,CAAC,MAAM,CAAC,iBAAiB;IA6BhC,MAAM,CAAC,sBAAsB,CAC3B,OAAO,EAAE;QACP,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,kBAAkB,CAAC,EAAE,MAAM,CAAC;QAC5B,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,kBAAkB,CAAC,EAAE,MAAM,CAAC;QAC5B,kBAAkB,CAAC,EAAE,MAAM,CAAC;KAC7B,EACD,UAAU,EAAE,iBAAiB,GAC5B,uBAAuB;IA0B1B,MAAM,CAAC,6BAA6B,CAClC,OAAO,EAAE;QACP,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,cAAc,CAAC,EAAE,MAAM,CAAC;KACzB,EACD,UAAU,EAAE,iBAAiB,GAC5B,uBAAuB;IAwB1B,MAAM,CAAC,oBAAoB,CACzB,OAAO,EAAE;QACP,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,qBAAqB,CAAC,EAAE,MAAM,CAAC;QAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB,EACD,UAAU,EAAE,iBAAiB,GAC5B,uBAAuB;IAyB1B,MAAM,CAAC,2BAA2B,CAChC,OAAO,EAAE;QACP,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,kBAAkB,CAAC,EAAE,MAAM,CAAC;KAC7B,EACD,UAAU,EAAE,iBAAiB,GAC5B,uBAAuB;CAsB3B"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AnomalySeverity as AnomalySeverityEnum, ViolationType as ViolationTypeEnum } from '../enums/index.js';
|
|
2
|
-
import { REQUEST_METRICS_TO_VALIDATE_KEYS,
|
|
2
|
+
import { REQUEST_METRICS_TO_VALIDATE_KEYS, CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS, CACHE_METRICS_TO_VALIDATE_KEYS, STABLE_BUFFER_METRICS_TO_VALIDATE_KEYS } from '../constants/index.js';
|
|
3
3
|
export class MetricsValidator {
|
|
4
4
|
static validateMetric(metricName, metricValue, guardrail) {
|
|
5
5
|
if (guardrail.min !== undefined && metricValue < guardrail.min) {
|
|
@@ -88,18 +88,13 @@ export class MetricsValidator {
|
|
|
88
88
|
validatedAt: new Date().toISOString()
|
|
89
89
|
};
|
|
90
90
|
}
|
|
91
|
-
static
|
|
91
|
+
static validateCircuitBreakerMetrics(metrics, guardrails) {
|
|
92
92
|
const anomalies = [];
|
|
93
|
-
const
|
|
93
|
+
const cbGuardrails = guardrails.infrastructure?.circuitBreaker || {};
|
|
94
94
|
const metricsToValidate = [
|
|
95
|
-
{ name:
|
|
96
|
-
{ name:
|
|
97
|
-
{ name:
|
|
98
|
-
{ name: API_GATEWAY_METRICS_TO_VALIDATE_KEYS[3], value: metrics.successRate, guardrail: gatewayGuardrails.successRate || guardrails.common?.successRate },
|
|
99
|
-
{ name: API_GATEWAY_METRICS_TO_VALIDATE_KEYS[4], value: metrics.failureRate, guardrail: gatewayGuardrails.failureRate || guardrails.common?.failureRate },
|
|
100
|
-
{ name: API_GATEWAY_METRICS_TO_VALIDATE_KEYS[5], value: metrics.executionTime, guardrail: gatewayGuardrails.executionTime || guardrails.common?.executionTime },
|
|
101
|
-
{ name: API_GATEWAY_METRICS_TO_VALIDATE_KEYS[6], value: metrics.throughput, guardrail: gatewayGuardrails.throughput || guardrails.common?.throughput },
|
|
102
|
-
{ name: API_GATEWAY_METRICS_TO_VALIDATE_KEYS[7], value: metrics.averageRequestDuration, guardrail: gatewayGuardrails.averageRequestDuration }
|
|
95
|
+
{ name: CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[0], value: metrics.failureRate, guardrail: cbGuardrails.failureRate },
|
|
96
|
+
{ name: CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[1], value: metrics.totalRequests, guardrail: cbGuardrails.totalRequests },
|
|
97
|
+
{ name: CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[2], value: metrics.failedRequests, guardrail: cbGuardrails.failedRequests }
|
|
103
98
|
];
|
|
104
99
|
for (const { name, value, guardrail } of metricsToValidate) {
|
|
105
100
|
if (value !== undefined && guardrail) {
|
|
@@ -114,178 +109,14 @@ export class MetricsValidator {
|
|
|
114
109
|
validatedAt: new Date().toISOString()
|
|
115
110
|
};
|
|
116
111
|
}
|
|
117
|
-
static
|
|
112
|
+
static validateCacheMetrics(metrics, guardrails) {
|
|
118
113
|
const anomalies = [];
|
|
119
|
-
const
|
|
114
|
+
const cacheGuardrails = guardrails.infrastructure?.cache || {};
|
|
120
115
|
const metricsToValidate = [
|
|
121
|
-
{ name:
|
|
122
|
-
{ name:
|
|
123
|
-
{ name:
|
|
124
|
-
{ name:
|
|
125
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[4], value: metrics.successfulRequests, guardrail: workflowGuardrails.successfulRequests },
|
|
126
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[5], value: metrics.failedRequests, guardrail: workflowGuardrails.failedRequests },
|
|
127
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[6], value: metrics.requestSuccessRate, guardrail: workflowGuardrails.requestSuccessRate || guardrails.common?.successRate },
|
|
128
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[7], value: metrics.requestFailureRate, guardrail: workflowGuardrails.requestFailureRate || guardrails.common?.failureRate },
|
|
129
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[8], value: metrics.executionTime, guardrail: workflowGuardrails.executionTime || guardrails.common?.executionTime },
|
|
130
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[9], value: metrics.averagePhaseExecutionTime, guardrail: workflowGuardrails.averagePhaseExecutionTime },
|
|
131
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[10], value: metrics.throughput, guardrail: workflowGuardrails.throughput || guardrails.common?.throughput },
|
|
132
|
-
{ name: WORKFLOW_METRICS_TO_VALIDATE_KEYS[11], value: metrics.phaseCompletionRate, guardrail: workflowGuardrails.phaseCompletionRate }
|
|
133
|
-
];
|
|
134
|
-
for (const { name, value, guardrail } of metricsToValidate) {
|
|
135
|
-
if (value !== undefined && guardrail) {
|
|
136
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
137
|
-
if (anomaly)
|
|
138
|
-
anomalies.push(anomaly);
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
return {
|
|
142
|
-
isValid: anomalies.length === 0,
|
|
143
|
-
anomalies,
|
|
144
|
-
validatedAt: new Date().toISOString()
|
|
145
|
-
};
|
|
146
|
-
}
|
|
147
|
-
static validatePhaseMetrics(metrics, guardrails) {
|
|
148
|
-
const anomalies = [];
|
|
149
|
-
const phaseGuardrails = guardrails.phase || {};
|
|
150
|
-
const metricsToValidate = [
|
|
151
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[0], value: metrics.totalRequests, guardrail: phaseGuardrails.totalRequests },
|
|
152
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[1], value: metrics.successfulRequests, guardrail: phaseGuardrails.successfulRequests },
|
|
153
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[2], value: metrics.failedRequests, guardrail: phaseGuardrails.failedRequests },
|
|
154
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[3], value: metrics.requestSuccessRate, guardrail: phaseGuardrails.requestSuccessRate || guardrails.common?.successRate },
|
|
155
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[4], value: metrics.requestFailureRate, guardrail: phaseGuardrails.requestFailureRate || guardrails.common?.failureRate },
|
|
156
|
-
{ name: PHASE_METRICS_TO_VALIDATE_KEYS[5], value: metrics.executionTime, guardrail: phaseGuardrails.executionTime || guardrails.common?.executionTime }
|
|
157
|
-
];
|
|
158
|
-
for (const { name, value, guardrail } of metricsToValidate) {
|
|
159
|
-
if (value !== undefined && guardrail) {
|
|
160
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
161
|
-
if (anomaly)
|
|
162
|
-
anomalies.push(anomaly);
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
return {
|
|
166
|
-
isValid: anomalies.length === 0,
|
|
167
|
-
anomalies,
|
|
168
|
-
validatedAt: new Date().toISOString()
|
|
169
|
-
};
|
|
170
|
-
}
|
|
171
|
-
static validateBranchMetrics(metrics, guardrails) {
|
|
172
|
-
const anomalies = [];
|
|
173
|
-
const branchGuardrails = guardrails.branch || {};
|
|
174
|
-
const metricsToValidate = [
|
|
175
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[0], value: metrics.totalPhases, guardrail: branchGuardrails.totalPhases },
|
|
176
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[1], value: metrics.completedPhases, guardrail: branchGuardrails.completedPhases },
|
|
177
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[2], value: metrics.failedPhases, guardrail: branchGuardrails.failedPhases },
|
|
178
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[3], value: metrics.phaseCompletionRate, guardrail: branchGuardrails.phaseCompletionRate },
|
|
179
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[4], value: metrics.totalRequests, guardrail: branchGuardrails.totalRequests },
|
|
180
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[5], value: metrics.successfulRequests, guardrail: branchGuardrails.successfulRequests },
|
|
181
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[6], value: metrics.failedRequests, guardrail: branchGuardrails.failedRequests },
|
|
182
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[7], value: metrics.requestSuccessRate, guardrail: branchGuardrails.requestSuccessRate || guardrails.common?.successRate },
|
|
183
|
-
{ name: BRANCH_METRICS_TO_VALIDATE_KEYS[8], value: metrics.executionTime, guardrail: branchGuardrails.executionTime || guardrails.common?.executionTime }
|
|
184
|
-
];
|
|
185
|
-
for (const { name, value, guardrail } of metricsToValidate) {
|
|
186
|
-
if (value !== undefined && guardrail) {
|
|
187
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
188
|
-
if (anomaly)
|
|
189
|
-
anomalies.push(anomaly);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
return {
|
|
193
|
-
isValid: anomalies.length === 0,
|
|
194
|
-
anomalies,
|
|
195
|
-
validatedAt: new Date().toISOString()
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
static validateInfrastructureMetrics(infrastructureMetrics, guardrails) {
|
|
199
|
-
const anomalies = [];
|
|
200
|
-
const infraGuardrails = guardrails.infrastructure || {};
|
|
201
|
-
if (infrastructureMetrics.circuitBreaker && infraGuardrails.circuitBreaker) {
|
|
202
|
-
const cb = infrastructureMetrics.circuitBreaker;
|
|
203
|
-
const cbGuardrails = infraGuardrails.circuitBreaker;
|
|
204
|
-
const cbMetrics = [
|
|
205
|
-
{ name: `circuitBreaker.${CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[0]}`, value: cb.failureRate, guardrail: cbGuardrails.failureRate },
|
|
206
|
-
{ name: `circuitBreaker.${CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[1]}`, value: cb.totalRequests, guardrail: cbGuardrails.totalRequests },
|
|
207
|
-
{ name: `circuitBreaker.${CIRCUIT_BREAKER_METRICS_TO_VALIDATE_KEYS[2]}`, value: cb.failedRequests, guardrail: cbGuardrails.failedRequests }
|
|
208
|
-
];
|
|
209
|
-
for (const { name, value, guardrail } of cbMetrics) {
|
|
210
|
-
if (value !== undefined && guardrail) {
|
|
211
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
212
|
-
if (anomaly)
|
|
213
|
-
anomalies.push(anomaly);
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
if (infrastructureMetrics.cache && infraGuardrails.cache) {
|
|
218
|
-
const cache = infrastructureMetrics.cache;
|
|
219
|
-
const cacheGuardrails = infraGuardrails.cache;
|
|
220
|
-
const cacheMetrics = [
|
|
221
|
-
{ name: `cache.${CACHE_METRICS_TO_VALIDATE_KEYS[0]}`, value: cache.hitRate, guardrail: cacheGuardrails.hitRate },
|
|
222
|
-
{ name: `cache.${CACHE_METRICS_TO_VALIDATE_KEYS[1]}`, value: cache.missRate, guardrail: cacheGuardrails.missRate },
|
|
223
|
-
{ name: `cache.${CACHE_METRICS_TO_VALIDATE_KEYS[2]}`, value: cache.utilizationPercentage, guardrail: cacheGuardrails.utilizationPercentage },
|
|
224
|
-
{ name: `cache.${CACHE_METRICS_TO_VALIDATE_KEYS[3]}`, value: cache.evictionRate, guardrail: cacheGuardrails.evictionRate }
|
|
225
|
-
];
|
|
226
|
-
for (const { name, value, guardrail } of cacheMetrics) {
|
|
227
|
-
if (value !== undefined && guardrail) {
|
|
228
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
229
|
-
if (anomaly)
|
|
230
|
-
anomalies.push(anomaly);
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
if (infrastructureMetrics.rateLimiter && infraGuardrails.rateLimiter) {
|
|
235
|
-
const rl = infrastructureMetrics.rateLimiter;
|
|
236
|
-
const rlGuardrails = infraGuardrails.rateLimiter;
|
|
237
|
-
const rlMetrics = [
|
|
238
|
-
{ name: `rateLimiter.${RATE_LIMITER_METRICS_TO_VALIDATE_KEYS[0]}`, value: rl.throttleRate, guardrail: rlGuardrails.throttleRate },
|
|
239
|
-
{ name: `rateLimiter.${RATE_LIMITER_METRICS_TO_VALIDATE_KEYS[1]}`, value: rl.queueLength, guardrail: rlGuardrails.queueLength },
|
|
240
|
-
{ name: `rateLimiter.${RATE_LIMITER_METRICS_TO_VALIDATE_KEYS[2]}`, value: rl.utilizationPercentage, guardrail: rlGuardrails.utilizationPercentage },
|
|
241
|
-
{ name: `rateLimiter.${RATE_LIMITER_METRICS_TO_VALIDATE_KEYS[3]}`, value: rl.averageQueueWaitTime, guardrail: rlGuardrails.averageQueueWaitTime }
|
|
242
|
-
];
|
|
243
|
-
for (const { name, value, guardrail } of rlMetrics) {
|
|
244
|
-
if (value !== undefined && guardrail) {
|
|
245
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
246
|
-
if (anomaly)
|
|
247
|
-
anomalies.push(anomaly);
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
if (infrastructureMetrics.concurrencyLimiter && infraGuardrails.concurrencyLimiter) {
|
|
252
|
-
const cl = infrastructureMetrics.concurrencyLimiter;
|
|
253
|
-
const clGuardrails = infraGuardrails.concurrencyLimiter;
|
|
254
|
-
const clMetrics = [
|
|
255
|
-
{ name: `concurrencyLimiter.${CONCURRENCY_LIMITER_METRICS_TO_VALIDATE_KEYS[0]}`, value: cl.utilizationPercentage, guardrail: clGuardrails.utilizationPercentage },
|
|
256
|
-
{ name: `concurrencyLimiter.${CONCURRENCY_LIMITER_METRICS_TO_VALIDATE_KEYS[1]}`, value: cl.queueLength, guardrail: clGuardrails.queueLength },
|
|
257
|
-
{ name: `concurrencyLimiter.${CONCURRENCY_LIMITER_METRICS_TO_VALIDATE_KEYS[2]}`, value: cl.averageQueueWaitTime, guardrail: clGuardrails.averageQueueWaitTime }
|
|
258
|
-
];
|
|
259
|
-
for (const { name, value, guardrail } of clMetrics) {
|
|
260
|
-
if (value !== undefined && guardrail) {
|
|
261
|
-
const anomaly = this.validateMetric(name, value, guardrail);
|
|
262
|
-
if (anomaly)
|
|
263
|
-
anomalies.push(anomaly);
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
return {
|
|
268
|
-
isValid: anomalies.length === 0,
|
|
269
|
-
anomalies,
|
|
270
|
-
validatedAt: new Date().toISOString()
|
|
271
|
-
};
|
|
272
|
-
}
|
|
273
|
-
static validateSchedulerMetrics(metrics, guardrails) {
|
|
274
|
-
const anomalies = [];
|
|
275
|
-
const schedulerGuardrails = guardrails.scheduler || {};
|
|
276
|
-
const metricsToValidate = [
|
|
277
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[0], value: metrics.totalJobs, guardrail: schedulerGuardrails.totalJobs },
|
|
278
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[1], value: metrics.queued, guardrail: schedulerGuardrails.queued },
|
|
279
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[2], value: metrics.running, guardrail: schedulerGuardrails.running },
|
|
280
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[3], value: metrics.completed, guardrail: schedulerGuardrails.completed },
|
|
281
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[4], value: metrics.failed, guardrail: schedulerGuardrails.failed },
|
|
282
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[5], value: metrics.dropped, guardrail: schedulerGuardrails.dropped },
|
|
283
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[6], value: metrics.totalRuns, guardrail: schedulerGuardrails.totalRuns },
|
|
284
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[7], value: metrics.successRate, guardrail: schedulerGuardrails.successRate || guardrails.common?.successRate },
|
|
285
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[8], value: metrics.failureRate, guardrail: schedulerGuardrails.failureRate || guardrails.common?.failureRate },
|
|
286
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[9], value: metrics.throughput, guardrail: schedulerGuardrails.throughput || guardrails.common?.throughput },
|
|
287
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[10], value: metrics.averageExecutionTime, guardrail: schedulerGuardrails.averageExecutionTime || guardrails.common?.executionTime },
|
|
288
|
-
{ name: SCHEDULER_METRICS_TO_VALIDATE_KEYS[11], value: metrics.averageQueueDelay, guardrail: schedulerGuardrails.averageQueueDelay }
|
|
116
|
+
{ name: CACHE_METRICS_TO_VALIDATE_KEYS[0], value: metrics.hitRate, guardrail: cacheGuardrails.hitRate },
|
|
117
|
+
{ name: CACHE_METRICS_TO_VALIDATE_KEYS[1], value: metrics.missRate, guardrail: cacheGuardrails.missRate },
|
|
118
|
+
{ name: CACHE_METRICS_TO_VALIDATE_KEYS[2], value: metrics.utilizationPercentage, guardrail: cacheGuardrails.utilizationPercentage },
|
|
119
|
+
{ name: CACHE_METRICS_TO_VALIDATE_KEYS[3], value: metrics.evictionRate, guardrail: cacheGuardrails.evictionRate }
|
|
289
120
|
];
|
|
290
121
|
for (const { name, value, guardrail } of metricsToValidate) {
|
|
291
122
|
if (value !== undefined && guardrail) {
|