mysql双主+keepalived

    为了实现mysql高可用,可以搭建双主模式。为了实现主节点故障自动切换,引入keepalived。

    这里因为要用到keepalived,使用docker感觉不太方便。因此这里就不用docker了。

一、双主

     其实双主的配置非常的简单,就是互为主从。两台机子分别配置为主节点和从节点就ok了。

     这里就不详细说了,可以参看以前的文章。

二、keepalived

    keepalived提供了一个虚拟ip,两个主通过选举,选举一个主绑定到虚拟ip。keepalived会根据配置监测两个主节点的服务是否存活,如果绑定了虚拟ip的服务挂了,可以执行配置的脚本,比如发送邮件,短信,重启主节点服务。另外,如果它同时监测keepalived的服务是否挂了,如果绑定了虚拟ip的节点的keepalived的服务挂了,它会重新选举一个主节点,把虚拟ip挂到新选举的主节点上。

    keepalived安装完成后,直接进行配置即可,比如:

!Configuration File for keepalived

global_defs {
    router_id LVS_MASTER
}

vrrp_script chk_mysql {
    script "/usr/local/script/chk_mysql.sh"
    interval 10
    weight 2
}

vrrp_instance VI_1 {
    state MASTER
    interface eno16777736
    virtual_router_id 51
    priority 100
    advert_init 1
    authentication {
      auth_type PASS
      auth_pass 1111
    }
    track_script {
      chk_mysql
    }
    virtual_ipaddress {
       192.168.160.200/24
    }
}

    该配置指定了虚拟ip,监测服务存活的脚本,监测时间间隔,失败后执行的脚本,keepalived之间的服务监测间等。详细配置项就不解释了。

    启动后可以通过ip a命令查看虚拟ip绑定在哪台机器上。

    最后补充一个监测mysql和发邮件的例子吧,该例子需要改进,不能直接用在生成环境

    该例子直接使用mailx和nc,不使用postfix,由于postfix发的邮件很容易被认为是垃圾邮件。

    1、安装mailx和nc

    2、配置/etc/mail.rc文件

set [email protected]
set smtp=smtp.163.com:25
set [email protected]
set smtp-auth-password=xxx
set smtp-auth=login
set ssl-verify=ignore
set nss-config-dir=/etc/maildbs/

     3、脚本

#!/bin/bash

nc -z -w2 localhost 3306
if [ $? -ne 0 ]
then
  echo "send mail"
  echo "mysql 192.168.160.66 3306 is down" | mail -s "mysql is down" [email protected]
fi


猜你喜欢

转载自blog.csdn.net/guduyishuai/article/details/80468471