MySQL高可用之MHA部署这篇博文中,已经将MHA的基础架构部署完成,但是并没有解决一个虚拟IP的问题,因为当master宕机后,新的master顶上来,这时前端APP要连接的数据库IP已经发生了变化,为了解决这个问题,必然要引入虚拟IP,谈起虚拟IP,首先想到的应该是keepalived这个工具,但这个工具有个弊端,就是有一个脑裂的问题,所以更建议在生产中使用脚本的方式来控制这个VIP。
1、在manager节点写入此脚本
[[email protected] scripts]# cat /scripts/master_ip_failover
#!/usr/bin/env perl
use strict;
use warnings FATAL => ‘all‘;
use Getopt::Long;
my (
$command,$ssh_user,$orig_master_host,$orig_master_ip,$orig_master_port,
$new_master_host,$new_master_ip,$new_master_port
);
my $vip = ‘192.168.20.100‘; #这里指定VIP地址
my $key = ‘0‘;
my $ssh_start_vip = "/sbin/ifconfig ens33:$key $vip"; #这条指令是启动VIP
my $ssh_stop_vip = "/sbin/ifconfig ens33:$key down"; #这条指令是停止VIP
GetOptions(
‘command=s‘