定时检测服务状态脚本实现

简介: 1、定时监测服务状态需求

背景:

当前有一服务实时在运行,从互联网搜索引擎(百度、360、bing等)搜索结果并返回。由于该服务被多个进程调用,负载均衡机制处理的并不好。

要求:

1)、定时监测该服务的返回状态,出现错误后,邮件告警。

2)、周期可以自定义。


2、定时监测服务状态实现

[root@lasearch]# cat running.sh


#!/bin/sh


step=5 #间隔的秒数,不能大于60

for(( i = 0; i < 60; i=(i+step))); do


 DOWN_LOG="/home/yy/search/down_log.txt"

 SUCC_LOG="/home/yy/search/success_log.txt"

 SEARCH_ADDR="110.128.8.252:19783"


 #cat /dev/null > $DOWN_LOG

 #cat /dev/null > $SUCC_LOG


 curTime=`date`

 rst=`curl http://$SEARCH_ADDR/search?word=%E5%8D%8E%E8%A5%BF%E5%8C%BB%E9%99%A2\&sid=baidu\&page=1\&sort=1\&ie=utf-8\&query_code=Ebc31058 | grep "{"`


 #echo "time = $curTime, rst = $rst"


 if [[ $rst == "" ]]; then

 echo "[$curTime] may be $SEARCH_ADDR is down!" >> $DOWN_LOG

 else

 echo "[$curTime] $SEARCH_ADDR is ok!" >> $SUCC_LOG

 fi

 sleep $step

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

关于邮件预警的思路:

1)同样上面shell脚本用Java探测实现,根据返回码来区分;

2)非200的实现邮件告警!Java自动邮件程序实现即可。


3、小结

需注意地方——curl中的url中含有”&”的时候,要加上”\”反斜杠处理。否则会报错。

相关文章
|
10月前
|
Shell 开发工具
【优化篇】telegraf+shell脚本实现秒级的服务状态异常监测与告警
【优化篇】telegraf+shell脚本实现秒级的服务状态异常监测与告警
218 0
|
Python
【python脚本】执行过程中触发若干次就停止执行脚本的方式
【python脚本】执行过程中触发若干次就停止执行脚本的方式
107 0
|
4月前
|
存储 Java 调度
Sppring集成Quartz简单案例详解 包括(添加、停止、恢复、删除任务、获取下次执行时间等)
Sppring集成Quartz简单案例详解 包括(添加、停止、恢复、删除任务、获取下次执行时间等)
56 2
|
监控
zabbix配置自动恢复动作
zabbix配置自动恢复动作
341 0
zabbix配置自动恢复动作
|
网络协议 Windows
【错误集】不定时更新
文章目录 前言 一、内容 二、服务(配置文件) 2.1 DNS服务无效(文件无权
184 0
【错误集】不定时更新
|
大数据 Python
Pythpn实现多脚本处理定时运行
Pythpn实现多脚本处理定时运行
167 0
Pythpn实现多脚本处理定时运行
|
测试技术
自动定时发送每日构建测试报告
自动定时发送每日构建测试报告
167 1
|
监控 Shell 应用服务中间件
使用crontab配合shell脚本定时检测拉起服务
使用crontab配合shell脚本定时检测拉起服务
276 0
|
调度 Python
定时功能
利用Py简单实现定时功能
|
Java Shell
定时检测服务状态脚本实现
定时检测服务状态脚本实现
557 0
定时检测服务状态脚本实现