监测的应用接口: 新闻接口、天气接口
处理方法:应用接口不可用时自动重启Tomcat,并发送告警邮件给相关人员
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
#!/bin/bash
#---------------------------------------------------------
# 功能说明:
# 监控指定HTTP服务是否可用,如果不可用立即重启Tomcat
#
# 使用说明:
# 1. 将此脚本放置在/home/opentsp/crontab/目录下。
# 2. 修改脚本执行权下为可执行权限。
# 3. 添加到定时任务中,定时执行时间(建议为20分钟)
# 4. 修改邮件发送人员信息列表(当服务重启时发邮件给相关人员)
# - 周凌飞(2014-08-13)
#---------------------------------------------------------
export LC_ALL=zh_CN.UTF-8
#网站地址、参数
SERVER_NAME= "趣驾云接口服务"
URL_2= "http://127.0.0.1/get_rss_news?p=%7b%27chId%27:%27TIYU%27%7d"
KeyWorld_2= '<title>'
URL_3= "http://127.0.0.1/get_json_weather?p=%7blon:116.407617,lat:39.993956,date:1%7d"
KeyWorld_3= 'temperature'
#邮件发送列表
mail_ary=(
xxxxxxxxx@navinfo.com
xxxxxxxxx@navinfo.com
xxxxxxxxx@navinfo.com
)
#接口调用失败的处理方法
function doFail(){
local ipinfo=$( ifconfig | sed -n '2p' | awk '{print substr($2,6)}' );
# 发送邮件
for _v in ${mail_ary[*]} ; do
echo "[$SERVER_NAME 异常] - [$(date -d " 0 min " +" %Y-%m-%d %H:%M:%S ")] - [请求地址: $1] - [请求返回码: $2]" | mail -s ${ipinfo}服务异常 ${_v}
done
# 写入日志
echo "[ERROR] - [$(date -d " 0 min " +" %Y-%m-%d %H:%M:%S ")] - 返回码[$2] - 重启Tomcat服务" >> detect-http.log
# 关闭Tomcat
sh /home/opentsp/crontab/ibr-shutdown .sh
exit ;
}
#请求超时时间设置
TIME_OUT=40
function doCheck(){
local URL_X=$1;
local KeyWorld_X=$2;
HTTP_STATUS_CODE=`curl -m $TIME_OUT -o /dev/null -s -w "%{http_code}" "${URL_X}" `
if [ $HTTP_STATUS_CODE != 200 ]; then
#请求失败
echo "-> Fail - 返回码${HTTP_STATUS_CODE}" ;
doFail ${URL_X} ${HTTP_STATUS_CODE};
else
#服务器正常响应,检查返回内容
if curl -m ${TIME_OUT} -s ${URL_X} | grep -q ${KeyWorld_X}; then
echo "-> SUCCESS" ;
else
echo "->> Fail" ;
# 返回内容错误处理
doFail ${URL_X} ${HTTP_STATUS_CODE};
fi
fi
}
#
#检查 - 新闻
doCheck ${URL_2} ${KeyWorld_2}
#检查 - 天气
doCheck ${URL_3} ${KeyWorld_3}
|
将以上代码放入到Linux的定时任务中即可,定时任务时间建议为20分钟一次。