52 lines
1.5 KiB
JavaScript
52 lines
1.5 KiB
JavaScript
var forever = require('forever-monitor');
|
|
var fs = require('fs-extra');
|
|
|
|
var getDateTimeString = () => {
|
|
var date = new Date();
|
|
var hour = date.getHours();
|
|
hour = (hour < 10 ? "0" : "") + hour;
|
|
var min = date.getMinutes();
|
|
min = (min < 10 ? "0" : "") + min;
|
|
var year = date.getFullYear();
|
|
var month = date.getMonth() + 1;
|
|
month = (month < 10 ? "0" : "") + month;
|
|
var day = date.getDate();
|
|
day = (day < 10 ? "0" : "") + day;
|
|
return year + "-" + month + "-" + day + "_" + hour + "-" + min;
|
|
};
|
|
var log_forever = './log/forever_'+getDateTimeString()+'.log';
|
|
var log_bot = './log/bot_'+getDateTimeString()+'.log';
|
|
var err_bot = './log/err_'+getDateTimeString()+'.log';
|
|
var putlog = (msg) => {
|
|
fs.appendFileSync(log_forever, msg, 'utf8');
|
|
};
|
|
|
|
var child = new (forever.Monitor)('./src/main.js', {
|
|
max: 1,
|
|
silent: false,
|
|
args: [],
|
|
spinSleepTime: 2000,
|
|
watch: true,
|
|
watchIgnoreDotFiles: true,
|
|
watchIgnorePatterns: [
|
|
'*.log', 'b/*', 't/*', 'node_modules/*'
|
|
],
|
|
watchDirectory: __dirname,
|
|
outFile: log_bot,
|
|
errFile: err_bot
|
|
});
|
|
|
|
child.on('watch:restart', (info) => {
|
|
putlog('Restaring bot because ' + info.stat + ' changed\n');
|
|
});
|
|
child.on('restart', () => {
|
|
putlog('restarting bot for ' + child.times + ' time\n');
|
|
});
|
|
child.on('start', () => {
|
|
putlog('starting bot\n');
|
|
});
|
|
child.on('exit:code', (code) => {
|
|
putlog('detected bot exited with code ' + code + '\n');
|
|
child.restart();
|
|
});
|
|
child.start(); |