-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpm2.js
41 lines (33 loc) · 1.18 KB
/
pm2.js
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
const pm2 = require('pm2');
const pkg = require('./package');
let instances = process.env.WEB_CONCURRENCY || -1;
let maxMemory = process.env.WEB_MEMORY || 512;
console.log(`Starting server with ${instances} instances.`);
console.log(`You should see ${instances} random numbers logged.`);
const options = {
name: pkg.name,
script: pkg.main,
exec_mode: 'cluster',
instances: instances,
max_memory_restart : `${maxMemory}M`,
};
pm2.connect((err) => {
if (err) {
console.error(err);
process.exit(2);
}
pm2.start(options, (err) => {
if (err) return console.error('Error while launching applications', err.stack || err);
console.log('PM2 and application has been succesfully started');
// Display logs in standard output
pm2.launchBus((err, bus) => {
console.log('[PM2] Log streaming started');
bus.on('log:out', function(packet) {
console.log('[App:%s] %s', packet.process.name, packet.data);
});
bus.on('log:err', function(packet) {
console.error('[App:%s][Err] %s', packet.process.name, packet.data);
});
});
});
});