這兩天自己開發的
App
用戶不斷增加,導致低配的阿裡雲服務器上的
API
服務經常掛掉,
API
是
Java
寫的, 使用
Tomcat
作為應用服務器.如果沒有在電腦旁邊,那就很尴尬了,所以我們需要一個自動監測
Tomcat
, 出問題還可以重啟的腳本服務.Linux Centos6Tomcat 7
監控,自啟腳本
#!/bin/sh# 獲取tomcat進程ID /usr/local/tomcat_ds_apiTomcatID=$(ps -ef |grep tomcat |grep -w 'tomcat_ds_api'|grep -v 'grep'|awk '{print $2}')
# tomcat啟動程序(這裡注意tomcat實際安裝的路徑) StartTomcat=/usr/local/tomcat_ds_api/bin/startup.sh
# 定義要監控的頁面地址 WebUrl=https://xx.com/test.txt# 日志輸出 TomcatMonitorLog=/tmp/TomcatMonitor.log
Monitor()
{
echo "[info]開始監控tomcat...[$(date +'%F %H:%M:%S')]"
if [[ $TomcatID ]];then # 這裡判斷TOMCAT進程是否存在
echo "[info]當前tomcat進程ID為:$TomcatID,繼續檢測頁面..."
# 檢測是否啟動成功(成功的話頁面會返回狀態"200")
TomcatServiceCode=$(curl -s -o $GetPageInfo -m 10 --connect-timeout 10 $WebUrl -w %{http_code})
if [ $TomcatServiceCode -eq 200 ];then
echo "[info]頁面返回碼為$TomcatServiceCode,tomcat啟動成功,測試頁面正常......"
else
echo "[error]tomcat頁面出錯,請注意......狀態碼為$TomcatServiceCode,錯誤日志已輸出到$GetPageInfo"
echo "[error]頁面訪問出錯,開始重啟tomcat"
#kill -9 $TomcatID # 殺掉原tomcat進程
#sleep 3
#rm -rf $TomcatCache # 清理tomcat緩存
#$StartTomcat
fi
else
echo "[error]tomcat進程不存在!tomcat開始自動重啟..."
echo "[info]$StartTomcat,請稍候......"
#rm -rf $TomcatCache
$StartTomcat
fi
echo "------------------------------" }
Monitor>>$TomcatMonitorLog
腳本來自 linux浪子將腳本保存為
monitor.sh
文件, 然後給腳本執行權限
chmod a+x monitor.sh
如果出現
/bin/sh^M: bad interpreter: No such file or directory。
錯誤, 可以你的腳本文件格式不正確, 解決方案如下然後修改文件格式
#sh>vi filename
利用如下命令查看文件格式
:set ff 或 :set fileformat
可以看到如下信息
fileformat=dos 或 fileformat=unix
利用如下命令修改文件格式
:set ff=unix 或 :set fileformat=unix
:wq
最後再執行文件
#sh>./filename
OK, 我們的腳本算是完成了, 下面我們來執行一下看看效果
啟動腳本, 使用crontab 執行定時任務
啟動腳本
./monitor.sh
查看日志文件
cd tmptail -f TomcatMonitor.log[info]開始監控tomcat...[2016-05-19 20:43:01][info]當前tomcat進程ID為:19491,繼續檢測頁面...[info]頁面返回碼為200,tomcat啟動成功,測試頁面正常......
出現上面的信息證明腳本已經在監控了, 但是我們只是手動執行了一下, 我們需要的是實時的監控我們的服務, 下面我們使用
crontab
來執行我們的定時任務.
安裝crontab
使用
yum
安裝
crontab
服務
yum install vixie-cron
安裝成功, 看一下常用命令
/sbin/service crond start //啟動服務/sbin/service crond stop //關閉服務
/sbin/service crond restart //重啟服務
/sbin/service crond reload //重新載入配置
查看crontab服務狀態:service crond status
手動啟動crontab服務:service crond start查看crontab服務是否已設置為開機啟動,執行命令:ntsysv
在CentOS系統中加入開機自動啟動:chkconfig --level 35 crond on
添加定時執行任務
*/1 * * * * /work/monitor.sh
1分鐘執行一次. 更多配置可以訪問 crontab 定時任務
測試
腳本建立好了, 定時任務也創建了, 接下來我們測試一把. 我們打開
log
文件觀察.關閉tomcat服務
ps -ef | grep javakill -9 pid
查看log
tail -f TomcatMonitor.log
[info]開始監控tomcat...[2016-05-19 21:02:01]
[info]當前tomcat進程ID為:19491,繼續檢測頁面...
[info]頁面返回碼為200,tomcat啟動成功,測試頁面正常......------------------------------[info]開始監控tomcat...[2016-05-19 21:03:01]
[error]tomcat進程不存在!tomcat開始自動重啟...
[info]/usr/local/tomcat_ds_api/bin/startup.sh,請稍候......
Tomcat started.------------------------------[info]開始監控tomcat...[2016-05-19 21:04:01]
[info]當前tomcat進程ID為:24948,繼續檢測頁面...
[info]頁面返回碼為200,tomcat啟動成功,測試頁面正常......------------------------------
我們看到當tomcat進程不存在了就會自動重啟了. 太棒了, 這樣我們不在電腦旁邊也不用怕了.