-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
60 lines (50 loc) · 1.67 KB
/
index.js
File metadata and controls
60 lines (50 loc) · 1.67 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
const app = require('./app');
const logger = require('./utils/logger');
const pool = require('./config/database');
const port = process.env.PORT || 3000;
const server = app.listen(port, () => {
logger.info('Ticketing system started', { port, nodeEnv: process.env.NODE_ENV || 'development' });
});
// Graceful shutdown
let isShuttingDown = false;
function gracefulShutdown(signal) {
if (isShuttingDown) {
logger.warn('Shutdown already in progress, ignoring signal', { signal });
return;
}
isShuttingDown = true;
logger.info('Graceful shutdown initiated', { signal });
// Stop accepting new connections, drain in-flight requests
server.close(async (err) => {
if (err) {
logger.error('Error closing HTTP server', { error: err.message, stack: err.stack });
} else {
logger.info('HTTP server closed');
}
// Close database pool (drain active queries)
try {
await pool.end();
logger.info('Database pool closed');
} catch (dbErr) {
logger.error('Error closing database pool', {
error: dbErr.message,
stack: dbErr.stack,
});
}
logger.info('Shutdown complete');
process.exit(0);
});
// Safety net: force exit before PM2 kill_timeout (5000ms) sends SIGKILL
setTimeout(() => {
logger.error('Forced shutdown after timeout');
process.exit(1);
}, 4500).unref();
}
process.on('SIGTERM', () => gracefulShutdown('SIGTERM'));
process.on('SIGINT', () => gracefulShutdown('SIGINT'));
// PM2 cluster mode shutdown message (ecosystem.config.js has shutdown_with_message: true)
process.on('message', (msg) => {
if (msg === 'shutdown') {
gracefulShutdown('PM2_SHUTDOWN_MESSAGE');
}
});