我將開始一個簡單的節點服務器,如果你殺了,monit會重新啓動它,如果設置正確,你也會收到一封電子郵件。
位置/home/xxx/monitoring/nodejs
文件:節點server.js
var http = require('http');
var port = 8002;
var fs = require('fs');
var logStream = fs.createWriteStream(port+"_log.txt", {'flags':'a'});
var count = 0;
http.createServer(function(req, res){
var output = (++count) + ' Request received in '+port+' @ ' + new Date()+'\n';
console.log(output);
logStream.write(output);
res.writeHead(200, {'Content-Type' : 'text/plain'});
res.end('From '+port+' @ ' + new Date());
}).listen(port);
console.log('Server running @ ' + port)
FILE:server.sh
#!/bin/bash
process=$1
PID_FILE="/home/xxx/monitoring/nodejs/file.pid"
case $process in
start)
echo "STARTING node js server in port 8002"
nohup /usr/sbin/node /home/xxx/monitoring/nodejs/node-server.js > /home/xxx/monitoring/nodejs/server.log 2>&1 &
echo $! > $PID_FILE
;;
stop)
kill -9 $(cat $PID_FILE)
rm $PID_FILE
;;
*)
echo "INVALID OPTION"
;;
esac
LOCATION:在/ etc/monit的/ monitrc(爲Ubuntu)
set mail-format {
from: [email protected]
subject: monit alert -- XXX-PROD $EVENT $SERVICE
message: $EVENT Service $SERVICE
Date: $DATE
Action: $ACTION
Host: $HOST
Description: $DESCRIPTION
Your faithful employee,
}
set mailserver smtp.gmail.com port 587 username "[email protected]" password "xxx" using tlsv1
set alert [email protected]
check process nodejs-server with pidfile /home/xxx/monitoring/nodejs/file.pid
start program = "/home/xxx/monitoring/nodejs/server.sh start"
stop program = "/home/xxx/monitoring/nodejs/server.sh stop
「
服務器運行後,點擊瀏覽器http://localhost:8002/。它會顯示一些結果。現在通過從'monit status'或其他方式找到它的進程id來終止進程。你會收到一封郵件,說這個過程不存在,但過了一段時間後,服務器會運行,你會收到一封郵件說'過程重新開始'。
但請記住,如果你從monit的命令停止過程就像
monit stop nodejs-server
然後它不會重新啓動。你會收到一封郵件,說你的流程已經停止。
它說:'程序1'進程沒有運行。試圖重新啓動。開始:/ bin/bash。無法啓動 – Zero 2014-11-23 18:30:18
請閱讀文檔,我不知道你做錯了什麼。你處理真正命名的「program1」? – 2014-11-23 19:48:28
,你應該開始處理,在monit可以與他合作之前。 – 2014-11-23 19:52:21