歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> Linux技術

Linux 監控tomcat,自動重啟tomcat服務

這兩天自己開發的
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進程不存在了就會自動重啟了. 太棒了, 這樣我們不在電腦旁邊也不用怕了.
Copyright © Linux教程網 All Rights Reserved