mysql 主备和双主模式_Keepalived+MySQL主主互备模式实现高可用

实验架构图:

302bad67f9dda864b7616bad5169f95e.gif

wKioL1SbeqHyGF7WAAEGk3sODA4346.jpg (32.88 KB, 下载次数: 2)

2014-12-26 08:44 上传

修改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创建复制用户

302bad67f9dda864b7616bad5169f95e.gif

wKioL1SbgXOzyPF5AAB3PKq6Os0325.jpg (15.72 KB, 下载次数: 0)

2014-12-26 08:44 上传

然后在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的运行状态

302bad67f9dda864b7616bad5169f95e.gif

wKioL1SbhH3QdWdOAAJBhRl9pYM736.jpg (61.18 KB, 下载次数: 0)

2014-12-26 08:44 上传

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

302bad67f9dda864b7616bad5169f95e.gif

wKioL1SbhRaxVtc5AAB3PKq6Os0925.jpg (15.72 KB, 下载次数: 0)

2014-12-26 08:44 上传

然后在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;

查看DB1上slave的运行状态

302bad67f9dda864b7616bad5169f95e.gif

wKiom1SbhjPxUXBjAAKZv1_WjLU955.jpg (70.08 KB, 下载次数: 0)

2014-12-26 08:44 上传

从状态看出复制服务运行正常,MySQL双主模式的主从复制配置完成。

配置Keepalived实现MySQL双主高可用

需要在两台服务器上安装keepalived,这里拿DB1安装过程举例,DB2的安装过程相同这里不重复。

tar xf keepalived-1.2.12.tar.gz

cd keepalived-1.2.12

./configure --sysconf=/etc --with-kernel-dir=/usr/src/kernels/2.6.32-504.el6.x86_64/

make

make install

DB1服务器配置文件 /etc/keepalived/keepalived.conf

global_defs {

notification_email {

root@localhost

}

notification_email_from keepalived.example.com

router_id MySQL_HA

}

vrrp_script check_mysqld {

script "/etc/keepalived/check_slave.pl 127.0.0.1"

interval 2

weight 21

}

vrrp_instance HA_1 {

state BACKUP      //DB1和DB2上均配置为BACKUP

interface eth0

virtual_router_id 80

priority 100

advert_int 2

nopreempt      //不抢占模式,只在优先级高的机器上设置即可,优先级低的机器可以不设置。

authentication {

auth_type PASS

auth_pass 23b14455cd

}

track_script {

check_mysqld

}

virtual_ipaddress {

192.168.0.150

}

}

其中,/etc/keepalived/check_slave.pl  脚本内容为:

#!/usr/bin/perl -w

use DBI;

use DBD::mysql;

# CONFIG VARIABLES

$SBM = 120;

$db = "wpdb";

$host = $ARGV[0];

$port = 3306;

$user = "root";

$pw = "123456";

# SQL query

$query = "show slave status";

$dbh = DBI->connect("DBI:mysql:$db:$host:$port", $user, $pw, { RaiseError => 0,PrintError => 0 });

if (!defined($dbh)) {

exit 1;

}

$sqlQuery = $dbh->prepare($query);

$sqlQuery->execute;

$Slave_IO_Running =  "";

$Slave_SQL_Running = "";

$Seconds_Behind_Master = "";

while (my $ref = $sqlQuery->fetchrow_hashref()) {

$Slave_IO_Running = $ref->{'Slave_IO_Running'};

$Slave_SQL_Running = $ref->{'Slave_SQL_Running'};

$Seconds_Behind_Master = $ref->{'Seconds_Behind_Master'};

}

$sqlQuery->finish;

$dbh->disconnect();

if ( $Slave_IO_Running eq "No" || $Slave_SQL_Running eq "No" ) {

exit 1;

} else {

if ( $Seconds_Behind_Master > $SBM ) {

exit 1;

} else {

exit 0;

}

}

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

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

302bad67f9dda864b7616bad5169f95e.gif

wKiom1Sbn_GiqrKRAAEysQybBKs065.jpg (34.94 KB, 下载次数: 1)

2014-12-26 08:44 上传

使用以下命令可以解决:

# 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

302bad67f9dda864b7616bad5169f95e.gif

wKiom1SbknvxkZ91AAIARvzmG7A712.jpg (52.82 KB, 下载次数: 1)

2014-12-26 08:44 上传

302bad67f9dda864b7616bad5169f95e.gif

wKiom1SbktvS-2H9AAFtIG96YV8466.jpg (38.08 KB, 下载次数: 0)

2014-12-26 08:44 上传

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

302bad67f9dda864b7616bad5169f95e.gif

wKioL1SbnSmxn-3_AAHGuMxOX0Q529.jpg (49.92 KB, 下载次数: 0)

2014-12-26 08:44 上传

测试故障转移

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

302bad67f9dda864b7616bad5169f95e.gif

wKiom1Sbngrx37kTAAFswoBFAF8765.jpg (38.51 KB, 下载次数: 0)

2014-12-26 08:44 上传

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

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

302bad67f9dda864b7616bad5169f95e.gif

wKiom1SbnyHDj4vzAAItp-PDPKE779.jpg (61.6 KB, 下载次数: 0)

2014-12-26 08:44 上传

实验完成!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值