Tomcat 运行状态检测脚本
2017-05-24 23:50
423 查看
最近自己的服务器运行不太稳定,经常404。 原因就不细说了,404的错误表现一样,导致的原因却有很多T.T。于是就想写个脚本自动检测服务器状态,如果状态异常就自动重启tomcat。
首先分析一下实现思路
Linux服务器,第一反应就是shell脚本。 用shell访问一个静态页面 -> 获取状态码 -> 判断是否200 -> 如果不是200,restart Tomcat,然后这个脚本每过1小时执行一次,非常简单的逻辑,开搞!
利用curl访问页面
curl 是什么东西这里不多做介绍,熟悉的不用讲,不熟悉的可以度娘,这里只是一个简单的应用。curl最简单的应用:
返回了百度的html内容,但是我们需要的是http请求的状态码,所以需要加几个参数:
首先分析一下实现思路
Linux服务器,第一反应就是shell脚本。 用shell访问一个静态页面 -> 获取状态码 -> 判断是否200 -> 如果不是200,restart Tomcat,然后这个脚本每过1小时执行一次,非常简单的逻辑,开搞!
利用curl访问页面
curl 是什么东西这里不多做介绍,熟悉的不用讲,不熟悉的可以度娘,这里只是一个简单的应用。curl最简单的应用:
curl www.baidu.com
返回了百度的html内容,但是我们需要的是http请求的状态码,所以需要加几个参数:
curl -I -m 10 -o /dev/null -s -w %{http_code} http://www.baidu.com[/code]
上面这条命令会返回htt这里写代码片p请求的状态码。 到这里我们就拿到了服务器的状态。
写脚本重启Tomcat
作为一个shell小白,写这个脚本历经了好多坑总算能运行,在这里分享给有需要的小伙伴,有大神看到希望可以指点一二。#!/bin/bash #首先需要加载两个环境变量 source /etc/profile source /home/jqch/.bashrc #定义一个log文件存放运行结果 file="/home/jqch/apache-tomcat-7.0.76/logs/testresult.txt" #这里用到了上面说的crul获取状态码 code=`curl -I -m 10 -o /dev/null -s -w %{http_code} http://www.baidu.com` #判断是否是200,如果是200就打印log if [[ "$code" == "200" ]] then echo `date +"%Y-%m-%d %H:%M:%S"` run check script, server is ok >> /home/jqch/apache-tomcat-7.0.76/logs/testresult.txt else #如果不是200 就重启tomcat echo `date +"%Y-%m-%d %H:%M:%S"` run check script, but server is down!!!! >>$file echo `/home/jqch/apache-tomcat-7.0.76/bin/startup.sh`>>$file fi
很简单的脚本,需要注意的是echo 中运行脚本需要用 《`》 tab键上面那个点。
神奇的crontab
经过上面几步已经可以检测服务器状态并做出相应的操作了。最后需要解决的一个问题就是如果定时执行。万能的Linux有个叫crontab的东西,安装与使用这里不再赘述,直接来怎么用。有3个命令需要用到://列出所有定时任务 crontab -l //编辑,添加定时任务 crontab -e //删除定时任务<慎用> crontab -r
需要说一下的是添加定时任务的格式# Edit this file to introduce tasks to be run by cron. # # Each task to run has to be defined through a single line # indicating with different fields when the task will be run # and what command to run for the task # # To define the time you can provide concrete values for # minute (m), hour (h), day of month (dom), month (mon), # and day of week (dow) or use '*' in these fields (for 'any').# # Notice that tasks will be started based on the cron's system # daemon's notion of time and timezones. # # Output of the crontab jobs (including errors) is sent through # email to the user the crontab file belongs to (unless redirected). # # For example, you can run a backup of all your user accounts # at 5 a.m every week with: # 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/ # # For more information see the manual pages of crontab(5) and cron(8) # # m h dom mon dow command * */1 * * * /home/jqch/apache-tomcat-7.0.76/logs/test.sh
前面5个* 代表时间,分别是 分钟 (m), 小时-24小时 (h), 一个月中的第几天 (dom), 第几个月 (mon), 星期几 (dow)。
比如:#每天的1点30分 30 1 * * * command #每个小时 0 */1 * * * command
这里在使用crontab的时候遇到一个大坑,由于对这个定时任务的实现机制不太了解,实现到时间脚本确实执行了,但是tomcat里面的工程依然是404,但是手动运行tomcat的startup.sh 没有任何问题。看了tomcat的log发现是java版本不对。WTK,我服务器的java环境明明和打包时是一样的。于是就比较自己手动运行和crontab运行脚本时的异同,最后终于发现,是环境变量不同!crontab运行的环境变量和登陆用户运行的环境变量不同,这可如何是好,最后只能再shell脚本里面先source一下,这也是上面脚本需要source的原因。
最后我们看一下运行结果:2017-05-24 23:44:01 run check script, server is ok 2017-05-24 23:45:01 run check script, but server is down!!!! Tomcat started. 2017-05-24 23:46:03 run check script, server is ok
检测到server挂掉了,就start,下次检测一切正常
到此为止,整个脚本就写完了。虽然很简单,但是折腾了大半天。知识是一点一点积累的。在此分享给大家,也给自己做个记录。
相关文章推荐
- 检测tomcat运行状态,自动重启TOMCAT脚本SHELL
- 检测Tomcat运行状态,自动重启
- Shell脚本检测Tomcat是否正在运行
- windows下检测软件运行状态。脚本
- 制作定时任务,监控Tomcat是否处于启动如果不是启动状态,运行脚本启动tomcat。
- shell脚本监控tomcat服务运行状态,服务关闭后进行重启
- jav 3ff8 a exec检测tomcat服务处于何中状态(正常运行,启动中或停止中, 停止状态)
- shell脚本检查Tomcat运行状态
- Linux下检测Apache运行状态的脚本
- 一个检测MySQL状态的脚本
- Tomcat自动检测和重启脚本(Linux)
- nginx运行检测脚本
- python检测QQ在线状态脚本
- 写了一个简单的shell脚本监控mysql服务器运行状态
- 轻松接触一个检测MySQL状态的脚本
- 懒人脚本:sysinfo系统运行状态自动收集
- Nagios监控mfs运行状态插件脚本
- python脚本检测linux进程是否运行
- 检测tomcat服务状态,自动重启Tomcat
- 检测tomcat服务状态,并能自动重启的代码