分别检查服务器在Master/Slave状态下,各项服务是否正常,否则报警;

原来使用keepalived每隔1分钟调用,由于执行结果对keepalived的weight参数有影响,所以移动到外部,使用supervisord进行管理;

运行在后台,作为守护进程;

#!/bin/bash

htname=$(hostname)
vip="10.108.144.5"
epg01="10.108.144.1"
epg02="10.108.144.2"
error_number=0

function send_warn()
{
  echo "Begin to send email......"
  if [ $(ip addr | grep $epg01 | wc -l) -eq 1 ];then
  #EPG-01
    if [ -f /sunlight/python/slt_send_mail.py ];then
      if [ $(ping -w 1 -c 1 baidu.com | grep ttl | wc -l) -eq 1 ];then
        python /sunlight/python/slt_send_mail.py "$1"
      fi
    fi
  else
  #EPG-02
    ssh -p 2222 -i /usr/local/sunlight/sshkeys/init.pk -o StrictHostKeyChecking=no $epg01 "ping -w 1 -c 1 baidu.com"
    if [ $? -eq 0 ];then
      ssh -p 2222 -i /usr/local/sunlight/sshkeys/init.pk -o StrictHostKeyChecking=no $epg01 "python /sunlight/python/slt_send_mail.py \"$1\""
    fi
  fi
  echo "Send mail end......"
}

while true
do
  event_string="<p><span style='color:#FF0000'>发现运行时错误!</span></p>"
  error_number=0
  check_vip=$(ip addr | grep $vip | wc -l)
  check_cron=$(ls -l /etc/cron.d |grep "^-" | wc -l)
  check_smon=$(ps -ef | grep /usr/local/sunlight/smon | grep -v grep | wc -l)
  check_route=$(ip route | grep $vip | wc -l)
  check_ip_conflict=$(ps -ef | grep "check_server_ip_conflict.sh" | grep -v grep | wc -l)

  #master
  if [ $check_vip -eq 1 ];then
  echo "[ info ] `date "+%Y%m%d %H:%M:%S"` Server is in Master State!"
  echo "check cron......"
  echo "$check_cron"
  if [ $check_cron -lt 1 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Master状态下,/etc/cron.d/目录下定时任务文件不存在,请登录检查!</p>"
  fi
  echo "check smon......"
  echo "$check_smon"
  if [ $check_smon -ne 1 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Master状态下,smon进程不为1,请登录检查!</p>"
  fi
  echo "check route......"
  echo "$check_route"
  if [ $check_route -ne 1 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Master状态下,虚拟路由地址没有正确设置,请登录检查!</p>"
  fi
  echo "check_ip_conflict......"
  echo "$check_ip_conflict"
  if [[ $check_ip_conflict -ne 1 && $check_ip_conflict -ne 2 ]];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Master状态下,检测IP地址冲突的脚本没有正确运行,请登录检查!</p>"
  fi
fi

#slave
if [ $check_vip -ne 1 ];then
  echo "[ info ] `date "+%Y%m%d %H:%M:%S"` Server is in Slave State!"
  echo "check cron......"
  echo "$check_cron"
  if [ $check_cron -gt 0 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Slave状态下,/etc/cron.d/目录下定存在定时任务文件,请登录检查!</p>"
  fi

  echo "check smon......"
  echo "$check_smon"
  if [ $check_smon -ne 1 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Slave状态下,smon进程不为1,请登录检查!</p>"
  fi

  echo "check route......"
  echo "$check_route"
  if [ $check_route -eq 1 ];then
    error_number=1
    event_string="${event_string}<p>错误描述:服务器在Slave状态下,存在虚拟路由地址,请登录检查!</p>"
  fi

  echo "check_ip_conflict......"
  echo "$check_ip_conflict"
  if [[ $check_ip_conflict -ne 1 && $check_ip_conflict -ne 2 ]];then
    error_number=1
  event_string="${event_string}<p>错误描述:服务器在Slave状态下,检测IP地址冲突的脚本没有正确运行,请登录检查!</p>"
  fi
fi

event_string="${event_string}<p>消息来源:海南-三亚-亚特兰蒂斯酒店</p>"
event_string="${event_string}<p>hostname: ${htname}</p>"

if [ $error_number -eq 1 ];then
  echo $event_string
  send_warn "$event_string"
fi
sleep 60
done

检查服务器主从状态的脚本-check_server_state.sh的更多相关文章

  1. MSC服务器-主从检测脚本-check_server_state.sh

    说明: 发现keepalived会在凌晨自动进行主从切换,导致msc相关进程运行不稳定: 通过运行check_server_state.sh,及时终止/启动相关进程: 所有脚本使用supervisor ...

  2. 检查Mysql主从状态

    .检查MySQL主从同步状态 #!/bin/bash USER=bak PASSWD=123456 IO_SQL_STATUS=$(mysql -u$USER -p$PASSWD -e  show s ...

  3. 分布式项目中 linux 服务器 部署jar 应用脚本 deploy.sh

    在实际项目的部署中,尤其是分布式项目,有很多服务的jar包需要 部署,这里抽取出公用的 deploy的脚本 下面是不含jdk配置的 #!/bin/bash JAVA_OPTIONS_INITIAL=- ...

  4. 编译安装nrpe,配置监控mysql端口和主从状态

    1.安装插件 # tar xvf nagios-plugins-1.4.13.tar.gz # cd nagios-plugins-1.4.13 # ./configure # make && ...

  5. 脚本_监控 HTTP 服务器的状态

    #!bin/bash#功能:监控 HTTP 服务器的状态(测试返回码) #作者:liusingbon#设置变量,url 为你需要检测的目标网站的网址(IP 或域名)url=http://192.168 ...

  6. 监控 HTTP 服务器的状态(测试返回码)shell脚本

    #!/bin/bash # 监控 HTTP 服务器的状态(测试返回码) # 设置变量,url为你需要检测的目标网站的网址(IP 或域名),比如百度 url=http://http://183.232. ...

  7. python MySQL-Slave从服务器状态检测脚本

    #!/bin/bash mysql -e "show slave status\G" > mysql_status.txt array=($(egrep 'Slave_IO_ ...

  8. 如何编写LVS对Real Server的健康状态检测脚本

    简介:Linux 虚拟服务器(Linux Virtual Server. LVS),是一个由章文松开发的自由软件.利用KVS可以实现高可用的.可伸缩缩的Web, Mail, Cache和Medial等 ...

  9. Linux检查服务器是否被入侵

    Linux检查服务器是否被入侵 检查root用户是否被纂改 awk -F: '$3==0{print $1}' /etc/passwd awk -F: '$3==0 {print}' /etc/pas ...

随机推荐

  1. [转]使用CMS垃圾收集器产生的问题和解决方案

    在之前的一篇文章<CMS vs. Parallel GC>里通过实验的方式对比了并行和并发GC的优缺点,在文章结尾提到,CMS并行GC是大多数应用的最佳选择,然而, CMS并不是完美的,在 ...

  2. 服务器性能调优(netstat监控大量ESTABLISHED连接与Time_Wait连接问题)

    netstat监控大量ESTABLISHED连接与Time_Wait连接问题 问题描述: 在不考虑系统负载.CPU.内存等情况下,netstat监控大量ESTABLISHED连接与Time_Wait连 ...

  3. 【例子】log4j.properties例子讲解

    log4j.rootLogger=info, ServerDailyRollingFile, stdout log4j.appender.ServerDailyRollingFile=org.apac ...

  4. mq(1):简介

    1.mq的使用场景 以前的我,一直都没太搞明白,为什么我们那么需要消息队列,直到我看到了网友scienjus.的这个例子. 例子:假设用户在你的软件中注册,服务端收到用户的注册请求后,它会做这些操作: ...

  5. SpringBoot 上传、下载(四)

    工程目录结构 完整代码: 1.pom.xml 首先当然是添加依赖,用到thymeleaf模板渲染html页面 <project xmlns="http://maven.apache.o ...

  6. 图解中序遍历线索化二叉树,中序线索二叉树遍历,C\C++描述

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  7. substr、substring和slice的区别

    substr(start,[length])表示从start位置开始取length个字符串:substring(start,end)表示从start,到end之间的字符串,包括start位置的字符但是 ...

  8. (C/C++学习笔记) 七. 类型转换

    七. 类型转换 ● 隐式类型转换 隐式类型转换 implicit type conversions #include<iostream> using namespace std; void ...

  9. 数学软件Matlab的使用感受

    在我一年前的暑假,我们的小学期学习了MATLAB软件.MATLAB是一款数学软件,可以用于算法计算.数据可视化.数据分析以及数据计算. 我们主要学习了MATLAB关于数学上的经常用的一些用法和算法,M ...

  10. matlab中文本文件与图像转化

    一  将图片转化为txt文本文件 a=imread('picture.bmp');   //读取picture.bmp图片 b=rgb2gray(a);                 //由rgb图 ...