-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.js
47 lines (39 loc) · 1.33 KB
/
main.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
42
43
44
45
46
47
/**
* Start PM2 Process Manager
*/
var pm2 = require('pm2');
var instances;
var maxMemory;
var execMode;
if (process.env.NODE_ENV === 'production') {
instances = process.env.WEB_CONCURRENCY || -1; // Set by Heroku or -1 to scale to max cpu core -1
maxMemory = process.env.WEB_MEMORY || 512; // " " "
execMode = 'cluster'; // ----> https://github.com/Unitech/PM2/blob/master/ADVANCED_README.md#schema
}
else {
instances = 1;
maxMemory = 512;
execMode = 'fork';
}
pm2.connect(function() {
pm2.start({
script : 'index.js',
name : 'api.classicaldb.org', // ----> THESE ATTRIBUTES ARE OPTIONAL:
exec_mode : execMode,
instances : instances,
max_memory_restart : maxMemory + 'M', // Auto restart if process taking more than XXmo
}, function(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(function(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);
});
});
});
});