您的位置:首页 > 博客中心 > 数据库 >

Keepalived+MySQL主主互备模式实现高可用      

时间:2022-03-14 04:15

    MySQL的高可用方案很多,这是一个配置简单而且实用的高可用解决方案。


实验架构图:


修改DB1配置文件增加以下几项:

[mysqld]

log-bin=mysql-bin

relay-log=mysql-relay-bin

server-id=1

replicate-wild-ignore-table=mysql.%

replicate-wild-ignore-table=test.%

replicate-wild-ignore-table=information_schema.%

                                         

修改DB2配置文件增加以下几项:

[mysqld]

log-bin=mysql-bin

relay-log=mysql-relay-bin

server-id=2

replicate-wild-ignore-table=mysql.%

replicate-wild-ignore-table=test.%

replicate-wild-ignore-table=information_schema.%


推荐在主从库上使用replicate-wild-ignore-table和replicate_wild_do_table两个选项来解决复制过滤的问题。


保证数据同步

    如果DB1上已经有MySQL数据,那么在执行主主互备之前,需要将DB1和DB2上的MySQL保持数据同步。

首先在DB1上执行锁表然后将数据导出,在DB2上应用。

锁表命令:FLUSH TABLES WITH READ LOCK;


创建复制用户并授权

    首先在DB1创建复制用户 

    然后在DB2的MySQL库中将DB1设为自己的主服务器


mysql> change master to \

    -> master_host=‘192.168.0.254‘,

    -> master_user=‘repl_user‘,

    -> master_password=‘123456‘,

    -> master_log_file=‘mysql-bin.000002‘,

    -> master_log_pos=106;


注意:master_log_file和master_log_pos这两个选项的值要对应在DB1上通过SQL语句"show master status" 查询到的值。


在DB2上启动Slave服务


mysql> start slave;


查看DB2上slave的运行状态

    这样DB1到DB2的主从复制已经完成,接下来配置从DB2到DB1的主从复制,这个过程和前面完全一样。首先在DB2的MySQL库中创建复制用户

然后在DB1的MySQL库中将DB2设为自己的主服务器

mysql> change master to \

    -> master_host=‘192.168.0.251‘,

    -> master_user=‘repl_user‘,

    -> master_password=‘123456‘,

    -> master_log_file=‘mysql-bin.000002‘,

    -> master_log_pos=106;


启动复制线程

mysql> start slave;


    exit 1;

} else {

    if ( $Seconds_Behind_Master > $SBM ) {

        exit 1;

    } else {

        exit 0;

    }

}


这是用Perl写的检测MySQL复制状态的脚本,修改文件中的MySQL数据库端口,用户名,密码即可直接使用。


如果执行这个脚本报如下错误时:

使用以下命令可以解决:

# yum install  perl-DBI perl-DBD-MySQL -y


DB2的keepalived.conf文件和DB1基本一样,只需将priority值修改为90,由于配置的是不抢占模式,还需要去掉nopreempt选项。


然后分别启动两台主机上的keepalived服务


测试服务的高可用功能


我们在192.168.0.3这台主机上用mysql客户端连接vip:192.168.0.150


从上面两张图可以看出来,目前是连到了192.168.0.254这台服务器上,也就表示游标IP在这台服务器上。



测试故障转移

故障模拟,我们这时手动停掉192.168.0.254的MySQL复制线程

这里可以看到,当停掉复制线程后,执行查询时连接中断了一次,马上再次连接上完成查询,显示的server_id已经变成2了,表示服务器已经切换了。


查看DB2服务器的IP地址验证游标IP是否转移过来了 


实验完成!

本文出自 “” 博客,转载请与作者联系!

热门排行

今日推荐

热门手游