标签:tomcat监控
前景描述,公司要求,在Linux Centos 服务器下,监控tomcat状态,如果tomcat端口不通,设置tomcat程序自动启动。20分钟检查一次。
tomcat安装的目录:/home/test/tomcat6/bin
#!/bin/bash
echo "Start"
URL="http://127.0.0.1/###/"
curlit()
{
#echo "??"
curl --connect-timeout 15 --max-time 20 --head --silent "$URL" | grep ‘200‘
# 上面的15是连接超时时间,若访问localhost的HTTP服务超过15s仍然没有正确响应200头代码,则判断为无法访问。
}
doit()
{
if ! curlit; then
# 如果localhost的apache服务没有正常返回200头,即出现异常。执行下述命令:
# echo "TD"
sleep 20
#top -n 1 -b >> /var/log/log.log
kill `ps -ef|grep java|grep -v grep |awk ‘{print $2}‘` > /dev/null 2>&1
# 这条语句中ps -ef|grep java|grep -v grep为查询进程中java进程同时排除本身语句,用awk找到第二列信息,返回状态扔到黑洞中。
sleep 2
cd /tomcat-6.0.29/bin/ #tomcat安装的路径
/bin/sh startup.sh
#echo "EN"
echo $(date) “Tomcat Restart” >> /var/log/log.log
# 写入日志
sleep 60
# 重启完成后等待,然后再次尝试一次
if ! curlit; then
# 如果仍然无法访问,则:
echo "@"
echo $(date) “Failed!” >> /var/log/log.log
# 写入apache依然重启失效的日志
fi
sleep 180
fi
}
sleep 3
# 运行脚本后才开始正式工作(防止重启服务器后由于tomcat还没开始启动造成误判)
# 主循环体
doit
我的脚本:
#!/bin/bash
echo "Start"
URL="http://127.0.0.1:8080/"
curlit()
{
#echo "??"
curl --connect-timeout 15 --max-time 20 --head --silent "$URL" | grep ‘200‘
}
doit()
{
if ! curlit; then
# echo "TD"
sleep 20
#top -n 1 -b >> /var/log/log.log
kill `ps -ef|grep java|grep -v grep |awk ‘{print $2}‘` > /dev/null 2>&1
sleep 2
cd /home/test/tomcat6/bin/
/bin/sh startup.sh
#echo "EN"
echo $(date) “Tomcat Restart” >> /var/log/log.log
sleep 60
if ! curlit; then
echo "@"
echo $(date) “Failed!” >> /var/log/log.log
fi
sleep 180
fi
}
sleep 3
doit
上面是脚本,创建脚本要在Linux下创建,步骤是:
1,用root账号进入
2,编写脚本
#touch jiankong1.sh
#vim jiankong1.sh
把上面的脚本复制到这个sh文件里面。
3,给脚本设置执行权限
chmod 700 jiankong1.sh
4,计划任务中添加该执行任务:
#crontab -e 按i进入编辑,和vim用法一样
输入:*/20 * * * * /home/jiankong1.sh
:wq!
5,检查执行任务中的程序
#crontab -l
本文出自 “ghost” 博客,请务必保留此出处http://fangwei009.blog.51cto.com/5234706/1632257
标签:tomcat监控
原文地址:http://fangwei009.blog.51cto.com/5234706/1632257