@platformatic/watt-admin 0.1.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 +201 -0
- package/README.md +68 -0
- package/cli.js +155 -0
- package/lib/start.js +19 -0
- package/package.json +59 -0
- package/watt.json +13 -0
- package/web/backend/dist/plugins/metrics.js +13 -0
- package/web/backend/dist/plugins/metrics.js.map +1 -0
- package/web/backend/dist/routes/root.js +84 -0
- package/web/backend/dist/routes/root.js.map +1 -0
- package/web/backend/dist/utils/calc.js +200 -0
- package/web/backend/dist/utils/calc.js.map +1 -0
- package/web/backend/dist/utils/log.js +29 -0
- package/web/backend/dist/utils/log.js.map +1 -0
- package/web/backend/platformatic.json +17 -0
- package/web/composer/platformatic.json +22 -0
- package/web/frontend/dist/.platformatic-build.json +1 -0
- package/web/frontend/dist/assets/index-BfyK1jrk.js +267 -0
- package/web/frontend/dist/assets/index-BfyK1jrk.js.map +1 -0
- package/web/frontend/dist/assets/index-D-ld0Cou.css +1 -0
- package/web/frontend/dist/browser-source-map-support.js +434 -0
- package/web/frontend/dist/favicon.svg +10 -0
- package/web/frontend/dist/fonts/Inter/Inter-VariableFont_wght.ttf +0 -0
- package/web/frontend/dist/fonts/Inter/OFL.txt +93 -0
- package/web/frontend/dist/fonts/Roboto_Mono/LICENSE.txt +202 -0
- package/web/frontend/dist/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf +0 -0
- package/web/frontend/dist/index.html +18 -0
- package/web/frontend/index.html +17 -0
- package/web/frontend/postcss.config.cjs +11 -0
- package/web/frontend/public/browser-source-map-support.js +434 -0
- package/web/frontend/public/favicon.svg +10 -0
- package/web/frontend/public/fonts/Inter/Inter-VariableFont_wght.ttf +0 -0
- package/web/frontend/public/fonts/Inter/OFL.txt +93 -0
- package/web/frontend/public/fonts/Roboto_Mono/LICENSE.txt +202 -0
- package/web/frontend/public/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf +0 -0
- package/web/frontend/watt.json +7 -0
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calcBytesToMB = exports.calculateMetrics = void 0;
|
|
4
|
+
const control_1 = require("@platformatic/control");
|
|
5
|
+
const MAX_STORED_METRICS = 20;
|
|
6
|
+
const calculateMetrics = async ({ mappedMetrics, log }) => {
|
|
7
|
+
try {
|
|
8
|
+
const api = new control_1.RuntimeApiClient();
|
|
9
|
+
const runtimes = await api.getRuntimes();
|
|
10
|
+
for (const { pid } of runtimes) {
|
|
11
|
+
const date = new Date();
|
|
12
|
+
const aggregatedMemData = {
|
|
13
|
+
date,
|
|
14
|
+
rss: 0,
|
|
15
|
+
totalHeap: 0,
|
|
16
|
+
usedHeap: 0,
|
|
17
|
+
newSpace: 0,
|
|
18
|
+
oldSpace: 0
|
|
19
|
+
};
|
|
20
|
+
const aggregatedCpuData = {
|
|
21
|
+
date,
|
|
22
|
+
cpu: 0,
|
|
23
|
+
eventLoop: 0
|
|
24
|
+
};
|
|
25
|
+
const aggregatedLatencyData = {
|
|
26
|
+
date,
|
|
27
|
+
p90: 0,
|
|
28
|
+
p95: 0,
|
|
29
|
+
p99: 0
|
|
30
|
+
};
|
|
31
|
+
const aggregatedReqData = {
|
|
32
|
+
date,
|
|
33
|
+
count: 0,
|
|
34
|
+
rps: 0,
|
|
35
|
+
};
|
|
36
|
+
let aggregatedRss = 0;
|
|
37
|
+
const runtimeMetrics = await api.getRuntimeMetrics(pid, { format: 'json' });
|
|
38
|
+
if (!mappedMetrics[pid]) {
|
|
39
|
+
mappedMetrics[pid] = { services: {}, aggregated: { dataCpu: [], dataLatency: [], dataMem: [], dataReq: [] } };
|
|
40
|
+
}
|
|
41
|
+
const { services, entrypoint } = await api.getRuntimeServices(pid);
|
|
42
|
+
for (const { id: serviceId } of services) {
|
|
43
|
+
const isEntrypointService = entrypoint === serviceId;
|
|
44
|
+
if (!mappedMetrics[pid].services[serviceId]) {
|
|
45
|
+
mappedMetrics[pid].services[serviceId] = { dataCpu: [], dataLatency: [], dataMem: [], dataReq: [] };
|
|
46
|
+
}
|
|
47
|
+
const serviceMemData = {
|
|
48
|
+
date,
|
|
49
|
+
rss: 0,
|
|
50
|
+
totalHeap: 0,
|
|
51
|
+
usedHeap: 0,
|
|
52
|
+
newSpace: 0,
|
|
53
|
+
oldSpace: 0
|
|
54
|
+
};
|
|
55
|
+
const serviceCpuData = {
|
|
56
|
+
date,
|
|
57
|
+
cpu: 0,
|
|
58
|
+
eventLoop: 0
|
|
59
|
+
};
|
|
60
|
+
const serviceLatencyData = {
|
|
61
|
+
date,
|
|
62
|
+
p90: 0,
|
|
63
|
+
p95: 0,
|
|
64
|
+
p99: 0
|
|
65
|
+
};
|
|
66
|
+
const serviceReqData = {
|
|
67
|
+
date,
|
|
68
|
+
count: 0,
|
|
69
|
+
rps: 0
|
|
70
|
+
};
|
|
71
|
+
for (const metric of runtimeMetrics) {
|
|
72
|
+
if (metric.values.length > 0) {
|
|
73
|
+
const [{ value, labels }] = metric.values;
|
|
74
|
+
if (metric.name === 'process_resident_memory_bytes') {
|
|
75
|
+
aggregatedRss = (0, exports.calcBytesToMB)(value);
|
|
76
|
+
}
|
|
77
|
+
if (serviceId === labels.serviceId) {
|
|
78
|
+
if (metric.name === 'nodejs_heap_size_total_bytes') {
|
|
79
|
+
serviceMemData.totalHeap = (0, exports.calcBytesToMB)(value);
|
|
80
|
+
aggregatedMemData.totalHeap += serviceMemData.totalHeap;
|
|
81
|
+
}
|
|
82
|
+
if (metric.name === 'nodejs_heap_size_used_bytes') {
|
|
83
|
+
serviceMemData.usedHeap = (0, exports.calcBytesToMB)(value);
|
|
84
|
+
aggregatedMemData.usedHeap += serviceMemData.usedHeap;
|
|
85
|
+
}
|
|
86
|
+
if (metric.name === 'nodejs_heap_space_size_used_bytes') {
|
|
87
|
+
metric.values.forEach(val => {
|
|
88
|
+
if (val.labels?.space === 'new') {
|
|
89
|
+
serviceMemData.newSpace = (0, exports.calcBytesToMB)(val.value);
|
|
90
|
+
aggregatedMemData.newSpace += serviceMemData.newSpace;
|
|
91
|
+
}
|
|
92
|
+
else if (val.labels?.space === 'old') {
|
|
93
|
+
serviceMemData.oldSpace = (0, exports.calcBytesToMB)(val.value);
|
|
94
|
+
aggregatedMemData.oldSpace += serviceMemData.oldSpace;
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
if (metric.name === 'thread_cpu_percent_usage') {
|
|
99
|
+
serviceCpuData.cpu = value;
|
|
100
|
+
aggregatedCpuData.cpu += serviceCpuData.cpu;
|
|
101
|
+
}
|
|
102
|
+
if (metric.name === 'nodejs_eventloop_utilization') {
|
|
103
|
+
serviceCpuData.eventLoop = value * 100;
|
|
104
|
+
aggregatedCpuData.eventLoop += serviceCpuData.eventLoop;
|
|
105
|
+
}
|
|
106
|
+
if (metric.name === 'http_request_all_summary_seconds') {
|
|
107
|
+
for (const metricValue of metric.values) {
|
|
108
|
+
const data = metricValue.value * 1000;
|
|
109
|
+
if (data > 0) {
|
|
110
|
+
if (metricValue.labels?.quantile === 0.9) {
|
|
111
|
+
serviceLatencyData.p90 = data;
|
|
112
|
+
if (isEntrypointService) {
|
|
113
|
+
aggregatedLatencyData.p90 = data;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
if (metricValue.labels?.quantile === 0.95) {
|
|
117
|
+
serviceLatencyData.p95 = data;
|
|
118
|
+
if (isEntrypointService) {
|
|
119
|
+
aggregatedLatencyData.p95 = data;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
if (metricValue.labels?.quantile === 0.99) {
|
|
123
|
+
serviceLatencyData.p99 = data;
|
|
124
|
+
if (isEntrypointService) {
|
|
125
|
+
aggregatedLatencyData.p99 = data;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
if (metric.name === 'http_request_duration_seconds') {
|
|
132
|
+
const count = metric.values.reduce((acc, { metricName, value, labels }) => {
|
|
133
|
+
const lastRouteChar = labels.route?.slice(-1);
|
|
134
|
+
if (metricName === 'http_request_duration_seconds_count' && lastRouteChar !== '/') {
|
|
135
|
+
acc += value;
|
|
136
|
+
}
|
|
137
|
+
return acc;
|
|
138
|
+
}, 0);
|
|
139
|
+
if (!count) {
|
|
140
|
+
log.debug(metric.values, 'Empty HTTP request count');
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
const req = mappedMetrics[pid].services[serviceId].dataReq;
|
|
144
|
+
const rps = count - (req[req.length - 1]?.count || 0);
|
|
145
|
+
serviceReqData.rps = rps;
|
|
146
|
+
serviceReqData.count = count;
|
|
147
|
+
if (isEntrypointService) {
|
|
148
|
+
aggregatedReqData.count = count;
|
|
149
|
+
aggregatedReqData.rps = rps;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
serviceMemData.rss = aggregatedRss;
|
|
157
|
+
aggregatedMemData.rss = aggregatedRss;
|
|
158
|
+
if (mappedMetrics[pid].services[serviceId].dataMem.length >= MAX_STORED_METRICS) {
|
|
159
|
+
mappedMetrics[pid].services[serviceId].dataMem.shift();
|
|
160
|
+
}
|
|
161
|
+
if (mappedMetrics[pid].services[serviceId].dataCpu.length >= MAX_STORED_METRICS) {
|
|
162
|
+
mappedMetrics[pid].services[serviceId].dataCpu.shift();
|
|
163
|
+
}
|
|
164
|
+
if (mappedMetrics[pid].services[serviceId].dataLatency.length >= MAX_STORED_METRICS) {
|
|
165
|
+
mappedMetrics[pid].services[serviceId].dataLatency.shift();
|
|
166
|
+
}
|
|
167
|
+
if (mappedMetrics[pid].services[serviceId].dataReq.length >= MAX_STORED_METRICS) {
|
|
168
|
+
mappedMetrics[pid].services[serviceId].dataReq.shift();
|
|
169
|
+
}
|
|
170
|
+
mappedMetrics[pid].services[serviceId].dataMem.push(serviceMemData);
|
|
171
|
+
mappedMetrics[pid].services[serviceId].dataCpu.push(serviceCpuData);
|
|
172
|
+
mappedMetrics[pid].services[serviceId].dataLatency.push(serviceLatencyData);
|
|
173
|
+
mappedMetrics[pid].services[serviceId].dataReq.push(serviceReqData);
|
|
174
|
+
}
|
|
175
|
+
if (mappedMetrics[pid].aggregated.dataMem.length >= MAX_STORED_METRICS) {
|
|
176
|
+
mappedMetrics[pid].aggregated.dataMem.shift();
|
|
177
|
+
}
|
|
178
|
+
if (mappedMetrics[pid].aggregated.dataCpu.length >= MAX_STORED_METRICS) {
|
|
179
|
+
mappedMetrics[pid].aggregated.dataCpu.shift();
|
|
180
|
+
}
|
|
181
|
+
if (mappedMetrics[pid].aggregated.dataLatency.length >= MAX_STORED_METRICS) {
|
|
182
|
+
mappedMetrics[pid].aggregated.dataLatency.shift();
|
|
183
|
+
}
|
|
184
|
+
if (mappedMetrics[pid].aggregated.dataReq.length >= MAX_STORED_METRICS) {
|
|
185
|
+
mappedMetrics[pid].aggregated.dataReq.shift();
|
|
186
|
+
}
|
|
187
|
+
mappedMetrics[pid].aggregated.dataMem.push(aggregatedMemData);
|
|
188
|
+
mappedMetrics[pid].aggregated.dataCpu.push(aggregatedCpuData);
|
|
189
|
+
mappedMetrics[pid].aggregated.dataLatency.push(aggregatedLatencyData);
|
|
190
|
+
mappedMetrics[pid].aggregated.dataReq.push(aggregatedReqData);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
catch (error) {
|
|
194
|
+
log.warn(error, 'Unable to get runtime metrics. Retry will start soon...');
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
exports.calculateMetrics = calculateMetrics;
|
|
198
|
+
const calcBytesToMB = (bytes) => Number((bytes / (1024 * 1024)).toFixed(2));
|
|
199
|
+
exports.calcBytesToMB = calcBytesToMB;
|
|
200
|
+
//# sourceMappingURL=calc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calc.js","sourceRoot":"","sources":["../../utils/calc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.getLogsFromReadable = void 0;
|
|
7
|
+
const split2_1 = __importDefault(require("split2"));
|
|
8
|
+
const promises_1 = require("node:stream/promises");
|
|
9
|
+
const MAX_LOGS = 1000;
|
|
10
|
+
const getLogsFromReadable = async (readable, log) => {
|
|
11
|
+
const result = [];
|
|
12
|
+
await (0, promises_1.pipeline)(readable, (0, split2_1.default)(), async function* (source) {
|
|
13
|
+
for await (const line of source) {
|
|
14
|
+
try {
|
|
15
|
+
const parsedObject = JSON.parse(line);
|
|
16
|
+
if (result.length >= MAX_LOGS) {
|
|
17
|
+
result.shift();
|
|
18
|
+
}
|
|
19
|
+
result.push(parsedObject);
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
log?.warn({ line }, 'Invalid JSON line found:');
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
return result;
|
|
27
|
+
};
|
|
28
|
+
exports.getLogsFromReadable = getLogsFromReadable;
|
|
29
|
+
//# sourceMappingURL=log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.js","sourceRoot":"","sources":["../../utils/log.ts"],"names":[],"mappings":";;;;;;AAAA,oDAA2B;AAE3B,mDAA+C;AAW/C,MAAM,QAAQ,GAAG,IAAI,CAAA;AAEd,MAAM,mBAAmB,GAAG,KAAK,EAAE,QAAkB,EAAE,GAAuB,EAAE,EAAE;IACvF,MAAM,MAAM,GAAU,EAAE,CAAA;IAExB,MAAM,IAAA,mBAAQ,EACZ,QAAQ,EACR,IAAA,gBAAM,GAAE,EACR,KAAK,SAAU,CAAC,EAAE,MAAM;QACtB,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;gBACrC,IAAI,MAAM,CAAC,MAAM,IAAI,QAAQ,EAAE,CAAC;oBAC9B,MAAM,CAAC,KAAK,EAAE,CAAA;gBAChB,CAAC;gBACD,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC3B,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,0BAA0B,CAAC,CAAA;YACjD,CAAC;QACH,CAAC;IACH,CAAC,CACF,CAAA;IAED,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAtBY,QAAA,mBAAmB,uBAsB/B"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://schemas.platformatic.dev/@platformatic/service/2.55.0.json",
|
|
3
|
+
"service": {
|
|
4
|
+
"openapi": true
|
|
5
|
+
},
|
|
6
|
+
"watch": true,
|
|
7
|
+
"plugins": {
|
|
8
|
+
"paths": [
|
|
9
|
+
{
|
|
10
|
+
"path": "./plugins",
|
|
11
|
+
"encapsulate": false
|
|
12
|
+
},
|
|
13
|
+
"./routes"
|
|
14
|
+
],
|
|
15
|
+
"typescript": "{PLT_BACKEND_TYPESCRIPT}"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://schemas.platformatic.dev/@platformatic/composer/2.55.0.json",
|
|
3
|
+
"composer": {
|
|
4
|
+
"services": [
|
|
5
|
+
{
|
|
6
|
+
"id": "backend",
|
|
7
|
+
"openapi": {
|
|
8
|
+
"url": "/documentation/json",
|
|
9
|
+
"prefix": "/api"
|
|
10
|
+
}
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
"id": "frontend",
|
|
14
|
+
"proxy": {
|
|
15
|
+
"prefix": "/"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
],
|
|
19
|
+
"refreshTimeout": 1000
|
|
20
|
+
},
|
|
21
|
+
"watch": true
|
|
22
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"basePath":"/"}
|