-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathindex.js
More file actions
83 lines (65 loc) · 2.18 KB
/
index.js
File metadata and controls
83 lines (65 loc) · 2.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
require('dotenv').config();
const express = require('express');
const path = require('path');
const itemsRouter = require('./src/routes/items');
const dbCheckRouter = require('./src/db-check');
const { db } = require('./src/sqliteDb');
// Simple metrics collection
let requestCount = 0;
let requestDuration = [];
const startTime = Date.now();
const app = express();
// Metrics middleware
app.use((req, res, next) => {
const start = Date.now();
requestCount++;
res.on('finish', () => {
const duration = Date.now() - start;
requestDuration.push(duration);
// Keep only last 1000 requests for memory efficiency
if (requestDuration.length > 1000) {
requestDuration = requestDuration.slice(-1000);
}
});
next();
});
app.use(express.json());
app.use(express.static('public'));
app.use('/items', itemsRouter);
app.use('/db', dbCheckRouter);
// Health check endpoint
app.get('/health', (req, res) => {
res.json({ status: 'ok', service: 'simple-application' });
});
// Prometheus metrics endpoint
app.get('/metrics', (req, res) => {
const uptime = Date.now() - startTime;
const avgDuration = requestDuration.length > 0
? requestDuration.reduce((a, b) => a + b, 0) / requestDuration.length
: 0;
const metrics = `
# HELP http_requests_total Total number of HTTP requests
# TYPE http_requests_total counter
http_requests_total ${requestCount}
# HELP http_request_duration_ms Average HTTP request duration in milliseconds
# TYPE http_request_duration_ms gauge
http_request_duration_ms ${avgDuration}
# HELP app_uptime_seconds Application uptime in seconds
# TYPE app_uptime_seconds gauge
app_uptime_seconds ${Math.floor(uptime / 1000)}
# HELP nodejs_version_info Node.js version information
# TYPE nodejs_version_info gauge
nodejs_version_info{version="${process.version}"} 1
`;
res.set('Content-Type', 'text/plain');
res.send(metrics);
});
// Default route
app.get('/', (req, res) => {
res.sendFile(path.join(__dirname, 'public', 'index.html'));
});
const PORT = process.env.PORT || 2019;
const HOST = process.env.NODE_ENV === 'production' ? '0.0.0.0' : 'localhost';
app.listen(PORT, HOST, () => {
console.log(`Server running on http://${HOST}:${PORT}`);
});