Linux下Tomcat服務監聽,關閉後自動重啓

本教程用來解決,linux下tomcat服務,因爲各種原因異常關閉後,實現自動重啓服務,保證服務可用

  1. 主要用到了Crontab命令:具體參照前人的教程別人的關於Crontab命令的教程
  2. 還用到一個自啓動腳本
#!/bin/sh

# func:自動監控tomcat腳本並且執行重啓操作
# author:EagleHao
# date:2018-04-08
# DEFINE

# 獲取tomcat進程ID(其中[grep -w 'tomcat']代碼中的tomcat需要替換爲你的tomcat文件夾名)
TomcatID=$(ps -ef |grep tomcat |grep -w 'apache-tomcat-h'|grep -v 'grep'|awk '{print $2}')

# tomcat啓動程序(這裏注意tomcat實際安裝的路徑)
StartTomcat=/usr/local/tomcat/apache-tomcat-h/bin/startup.sh
TomcatCache=/usr/local/tomcat/apache-tomcat-h/work

#定義要監控的頁面地址
WebUrl=http://www.baidu.com

#日誌輸出
GetPageInfo=/tmp/TomcatMonitor.Info
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
  • 上面的腳本做好自己的配置修改後,將文件保存爲monitor.sh(具體叫啥你自己定)
  • 給腳本賦予執行權限:chmod a+x monitor.sh
  • 把這個腳本放到服務器上自己定義的目錄下比如/usr/local/tomcat/moniotr
  • 進入腳本放置的路徑,啓動腳本:./monitor.sh
  • 添加定時任務,指定如下命令:crontab -e
  • 定時任務設置語句:*/1 * * * * /腳本放置的路徑/monitor.sh(1代表每分鐘,具體時間參照博客上面的設置鏈接)
  • 以上如果都沒報錯的話,可以測試下把服務停止後,看看定時任務有沒有重啓服務

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章