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 from=xxx@163.com
set smtp=smtp.163.com:25
set smtp-auth-user=xxx@163.com
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" xxx@qq.com
fi


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL双主+Keepalived是一种高可用性架构,它允许在两个MySQL主服务器之间实现数据同步和故障切换。Keepalived是一个开源的高可用性解决方案,可用于监视和管理服务器的状态,并在主服务器出现故障时自动将流量切换到备用主服务器。 在MySQL双主架构中,两个主服务器都可以接收写入操作,并且彼此之间进行数据同步以保持数据一致性。当其中一个主服务器发生故障或需要维护时,Keepalived会检测到该状态变化,并将流量切换到备用主服务器,确保应用程序的持续可用性。 实现MySQL双主+Keepalived需要进行以下步骤: 1. 配置两个MySQL主服务器,确保它们能够相互通信并进行数据同步。可以使用MySQL的复制功能来实现数据的实时同步。 2. 安装和配置Keepalived,在两个主服务器上分别安装Keepalived软件包,并进行必要的配置。配置文件包括虚拟IP地址、监控检查脚本和故障切换设置等。 3. 启动Keepalived,保证两个主服务器上的Keepalived服务都在运行状态。 4. 进行故障测试,模拟其中一个主服务器宕机或网络故障的情况,观察Keepalived是否能够及时检测到故障并切换流量到备用主服务器。 5. 定期进行维护和监控,确保MySQL主服务器和Keepalived服务的稳定性。 需要注意的是,MySQL双主+Keepalived架构需要合理配置和管理,以确保数据一致性和高可用性。在进行故障切换时,可能会有一定的数据丢失或延迟,因此需要根据业务需求和数据重要性来评估和调整配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值