zoukankan      html  css  js  c++  java
  • keepalived故障切换邮件通知

    keepalived+nginx,实现nginx高可用,注意事项:1、VIP不需要在服务器网络配置文件中配置。2、nginx主不可用时,需要kill掉nginx主的keepalived服务,这样才可以实现VIP切换,因为主的keepalived优先级高。3、故障切换时发送邮件通知由nginx备的keepalived服务来实现。

    其中nginx主上keepalived.conf配置为:

    /etc/keepalived/keepalived.conf

    ! Configuration File for keepalived
    
    global_defs {
    #标识本节点的名称
       router_id master
    }
    
    vrrp_script chk_nginx {  
        script "/etc/keepalived/nginx_check.sh"
        #每2秒检测一次nginx的运行状态
        interval 2
        #失败一次,将自己的优先级调整为-20
        weight    -20
    } 
    
    vrrp_instance VI_1 {
        #状态,主节点为MASTER
        state MASTER
        #绑定VIP的网络接口
        interface ens33
        #虚拟路由的ID号,两个节点设置必须一样
        virtual_router_id 51
        #节点优先级,值范围0~254,MASTER>BACKUP
        priority 100
        #组播信息发送时间间隔,两个节点必须设置一样,默认为1秒
        advert_int 1
        #设置验证信息,两个节点必须一致
        authentication {
                auth_type PASS
                auth_pass 1111
            }
    
        #虚拟IP,两个节点设置必须一致,可以设置多个
        virtual_ipaddress {
                192.168.1.106
            }
            #nginx存活状态检测脚本
        track_script {
            chk_nginx
        }
    }

    其中调用的/etc/keepalived/nginx_check.sh脚本内容为:

    #!/bin/bash  
    A=`ps -C nginx -no-header |wc -l`
    if [ $A -eq 1 ];then
            pkill keepalived
    fi

    nginx备上keepalived.conf配置为:

    ! Configuration File for keepalived
    
    global_defs {
            #标识本节点的名称
            router_id backup
    }
    
    vrrp_instance VI_1 {
            #状态,备节点为BACKUP
            state BACKUP
            #绑定VIP的网络接口
            interface ens33
            #虚拟路由的ID号,两个节点设置必须一样
            virtual_router_id 51
            #节点优先级,值范围0~254,MASTER>BACKUP
            priority 99
            #组播信息发送时间间隔,两个节点必须设置一样,默认为1秒
            advert_int 1
            #设置验证信息,两个节点必须一致
            authentication {
                    auth_type PASS
                    auth_pass 1111
            }
    
            #节点变为master时执行
            notify_master /etc/keepalived/send_mail.sh
    
            #虚拟IP,两个节点设置必须一致,可以设置多个
            virtual_ipaddress {
                    192.168.1.106
            }
    
    }

    里边调用的send_mail.sh脚本为使用Perl编写的,需要安装环境:

    yum -y install perl-CPAN
    cpan Net::SMTP_auth

    send_mail.sh脚本内容为:

    #!/usr/bin/perl -w  
    use Net::SMTP_auth;
    use strict;
    #smtp服务器 my $mailhost
    = 'smtp.exmail.qq.com';
    #发送邮件的邮箱 my $mailfrom
    = 'from@qq.com';
    #接收邮件的邮箱 my @mailto
    = ('to@qq.com');
    #邮件主题 my $subject
    = 'keepalived up on backup';
    #邮件正文 my $text
    = "正文 nginx-1服务器宕机!!nginx-2变为master!!!";
    #发送邮件的用户名 my $user
    = 'from@qq.com';
    #发送邮件的邮箱密码 my $passwd
    = '123456'; &SendMail(); ############################## # Send notice mail ############################## sub SendMail() { my $smtp = Net::SMTP_auth->new( $mailhost, Timeout => 120, Debug => 1 ) or die "Error. "; $smtp->auth( 'LOGIN', $user, $passwd ); foreach my $mailto (@mailto) { $smtp->mail($mailfrom); $smtp->to($mailto); $smtp->data(); $smtp->datasend("To: $mailto "); $smtp->datasend("From:$mailfrom "); $smtp->datasend("Subject: $subject "); $smtp->datasend(" "); $smtp->datasend("$text "); $smtp->dataend(); } $smtp->quit; }
  • 相关阅读:
    Log4net源码分析(一)
    找不到具有绑定 WSHttpBinding 的终结点的与方案 http 匹配的基址。注册的基址方案是 []。
    C#线程锁使用全功略
    C#泛型版的超级优化的快速排序算法和插入排序、二分查找算法
    用WM_COPYDATA实现进程通信
    构建插件式的应用程序框架(二)-订立契约
    Ajax网站安全,谁来保证
    构建插件式的应用程序框架(三)-动态加载
    构建插件式的应用程序框架(八)-视图服务的简单实现
    插件架构学习体会(一) 宿主程序说:插件你得听我的
  • 原文地址:https://www.cnblogs.com/John-2011/p/7838794.html
Copyright © 2011-2022 走看看