shell编写tomcat自动守护脚本

工作所需,匆匆忙忙写了个监控tomcat的shell脚本,大概思路是这样的:先检测tomcat进程是否存在,如果不存在就启动,如果进程存在,检测页面返回码状态,如果是200就是正常,如果不是就重启。


#!/bin/sh

# func:自动监控tomcat脚本并且执行重启操作
# author:reed
# date:12/09/2012

# 定义环境变量
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/java/jdk1.5.0_11/bin
export JAVA_HOME=/usr/java/jdk1.5.0_11
export CLASSPATH=$JAVA_HOME/lib:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin

# DEFINE

# 获取tomcat进程ID
TomcatID=$(ps -ef |grep tomcat |grep -w ‘apache-tomcat-5.5.23‘|grep -v ‘grep‘|awk ‘{print $2}‘)

# tomcat启动程序(这里注意tomcat实际安装的路径)
StartTomcat=/usr/apache-tomcat-5.5.23/bin/startup.sh
TomcatCache=/usr/apache-tomcat-5.5.23/work

# 定义要监控的页面地址
WebUrl=http://localhost:8080

# 日志输出
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

测试OK后把脚本加入到crontab。
时间: 2024-10-10 20:45:15

shell编写tomcat自动守护脚本的相关文章

用shell编写批量打包日志脚本

脚本1 #!/bin/bash DATE=$(date +%Y%m%d%H%M) NAME=$(echo $1 | awk -F',' '{print NF}') LOG_PATH="$2" if [ $# -ne 2 ];then     echo "USAGE: sh $0 log_name1,log_name2 log_path"     exit fi for NUM in `seq 1 $NAME` do     LOG_NAME=$(echo $1 | 

tomcat自动部署脚本

#!/bin/bash #defined now=`date +%Y%m%d%H%M%S` TOMCAT_HOME="/usr/tomcat7/apache-tomcat-7.0.70/" TOMCAT_PORT=8080 PROJECT="$1" BACKUP_DIR="/tomcat_back/$PROJECT/$now" #param validate; if [ $# -lt 1 ]; then echo "you must u

使用HTML+shell编写九九乘法口诀脚本

首先Linux操作系统需要安装好httpd,以测试脚本效果: 脚本内容如下: #!/bin/bash CURRENT_HTML=/var/www/html/index.html cat <<EOF > $CURRENT_HTML <html> <head> <title>九九乘法表</title> </head> <body> <table width="30%" border="

[ Tomcat ] 自动更新脚本

之前总是要更新基于 Tomcat 的web项目,而且更新频繁. 手工更新太烦人了,遂写了一个半自动的脚本.已经快一年没接触 Tomcat ,脚本仅供参考 . #!/bin/bash # Author: Jeffery.Su # Mail: [email protected] # Site: http://suzf.net # Date: Sep 10,2014 # Version: 1.0.2 # Definite variable PRO_NAME=javacenter WORK_PATH=/

利用Python编写linux自动备份脚本

题目: 周末的时候帮朋友写了一个备份需求的脚本,现在整理一下,分享出来使用Python语言的Fabric模块,这里就不扫盲了,运维必用的Python模块: 大概要求: 公司需求,每天凌晨2点备份数据(数据量不大,每天全备),拷贝至备份服务器,通过md5对比备份文件(本机备份文件和备份服务器文件对比),并将备份情况通知运维组同学. 备份思路: (1.每天凌晨2点在服务器本地使用tar打包备份文件: (2.备份成功以后,推送至备份服务器: (3.校验本地备份文件和备份服务器文件的完整性和一致性: (

python编写Mysql自动备份脚本

#!/usr/bin/env python # -*- coding: utf-8 -*-  # filename: mysql_dump.py import os import time import string ''' defined variable ''' databases='--database kbss_kcas reportdb koacif sequence infocenter' sql_user='root' sql_pwd='123456' ''' Defining t

实用脚本----Linux下Jdk和Tomcat自动安装shell脚本总结

系统环境为:ubuntu 14.04 一.JDK 自动安装脚本 jdk自动安装bash shell脚本,截止今天(2014/10/15)亲测可用: sudo su #切换到root权限 mkdir /usr/local/java cd /usr/local/java #download jdk 1.7.67 wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-securebackup-co

shell实现SSH自动登陆

前言 公司开发使用docker,每次登陆自己开发机总要输入 ssh [email protected]_string,然后再确认输入password,手快了还经常会输错.作为一个懒人,肯定要找一个取巧的方式,查看了下ssh命令,由于它要进行一次跟服务器的加密交互,所以没有直接附带密码登陆的选项,只好作罢. 前些天在同事进行技术分享时,看到他竟然只输入了一行命令./test.sh就成功登陆了开发机,甚是惊异,于是回来搜索研究了一下,遂成此文. shell脚本基础 在编写ssh自动登陆脚本之前,先说

mysql自动备份脚本及异地定时FTP

分享个自己写的mysql自动备份脚本.定时执行设置及windows自动FTP,请大家指教. 前提环境:mysql数据库服务器开启vsftpd,并配置合适帐号以便能被内网存储服务器FTP 第一步:编写mysql自动执行脚本 #!/bin/sh # mysql_db_backup.sh: backup mysql databases. # # Last updated: Wed Nov  9 07:01:01 CST 2011 # ----------------------------------