• 开发监测keepalived裂脑的脚本


    检测思路:在备节点上执行脚本,如果可以ping通主节点并且备节点有VIP就报警,让人员介入检查是否裂脑。

    在LB02备节点上开发脚本并执行:

    [root@lb02 ~]# cat /server/scripts/shell/check_split_brain.sh 
    #!/bin/bash
    #Author:Mr.Ding
    #Created Time:2018-10-05 17:11:33
    #Name:check_split_brain.sh
    #Description:监测keepalived裂脑的脚本.
    lb01_vip=192.168.200.16
    lb01_ip=192.168.100.105
    while true
    do
    ping -c 2 -W 3 $lb01_ip &>/dev/null
    	if [ $? -eq 0 -a `ip add|grep "$lb01_vip"|wc -l` -eq 1 ]
    		then
    			echo "ha is split brain.warning."
    	else
    			echo "ha is ok"
    	fi
    sleep 5
    done
    
    [root@lb02 shell]# sh check_split_brain.sh 
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    

     正常情况下主节点活着,VIP192.168.200.16在主节点,因此不会报警,提示“ha is ok”.

    停掉keepalived服务后看LB02脚本执行情况:

    在LB01上停止keepalived服务:
    [root@lb01 shell]# systemctl stop keepalived
    
    LB02上脚本执行情况如下:
    [root@lb02 shell]# sh check_split_brain.sh 
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    

     关掉Lb01服务器,再次查看LB02上脚本输出情况:

    [root@lb02 shell]# sh check_split_brain.sh 
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is split brain.warning.
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    ha is ok
    

     裂脑报警就恢复了。

  • 相关阅读:
    大型网站核心架构因素
    大型网站架构模式
    博客中的文章归档是如何实现的
    Caused by: java.sql.SQLException: Value '0000-00-00 00:00:00' can not be represented as java.sql.Timestamp
    git分支开发的好处
    layui之日期和时间组件
    vue-electron脚手架
    springboot1.5.4 配置druid1.1.0(使用druid-spring-boot-starter)
    Node.js读取文件内容并返回值(非异步)
    C# ftp ListFilesOnServer
  • 原文地址:https://www.cnblogs.com/Mr-Ding/p/9745317.html
Copyright © 2020-2023  润新知