Linux下设置监控tomcat端口脚本,优化版

领导要求脚本要长时间在系统后台运行,于是修改了上次的脚本,加了守护进程。我的脚本如下:


#!/bin/bash  

echo "Start"  

URL="http://127.0.0.1:8080/"

curlit()  

{

    #echo "??"  

curl --connect-timeout 10 --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 /home/test/tomcat6/bin/

nohup /home/test/tomcat6/bin/startup.sh >/home/jiankong.log &

#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

     



参考资料解释:

在启动weblogic的时候我们经常看到如下的命令:

nohup ./startWebLogic.sh >out.log 2>&1 &

从09年开始用weblogic到现在已经过去3年多了 ,今天终于将该命令理解清楚了。

其中 0、1、2分别代表如下含义:
 0 – stdin (standard input)
 1 – stdout (standard output)
 2 – stderr (standard error)

nohup ./startWebLogic.sh >out.log 2>&1 &

nohup+最后面的& 是让命令在后台执行

>out.log 是将信息输出到out.log日志中

2>&1 是将标准错误信息转变成标准输出,这样就可以将错误信息输出到out.log 日志里面来。


本文出自 “ghost” 博客,请务必保留此出处http://fangwei009.blog.51cto.com/5234706/1632947

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。