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;
查看DB1上slave的运行状态
从状态看出复制服务运行正常,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数据库端口,用户名,密码即可直接使用。
如果执行这个脚本报如下错误时:
使用以下命令可以解决:
# 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是否转移过来了
实验完成!