为了实现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