第98讲:MHA高可用集群VIP地址配置与漂移实践

1.为甚要给MHA高可用集群配置VIP地址

当主库发生故障,从库切换成主库后,程序是无感知的,程序并不知道谁成为了主库,程序还是会连接曾经的主库,就会导致平台访问异常,因此我们需要准备一个VIP漂移地址,当主库故障后,VIP就漂移到新的主库上,保证平台的高可用。

可以通过Keepalived实现高可用,当然MHA也有配置VIP的方法,并且非常简单。

MHA配置VIPD的方法,是通过一个脚本,自动判断谁是主库,然后在主库的网卡上添加一个VIP地址,当主库故障后自动将这个VIP地址删除,然后在新的主库中添加这个VIP地址。

2.配置MHA高可用集群VIP漂移地址

2.1.准备MHA VIP地址的脚本

[root@mysql-3 ~]# vim /data/mha/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.15/23';			#指定漂移IP地址
my $key = '1';						   #虚拟网卡号
my $ssh_start_vip = "/sbin/ifconfig ens192:$key $vip";    #ens192是我自己的网卡名称需要根据自己的情况而设置
my $ssh_stop_vip = "/sbin/ifconfig ens192:$key down";

GetOptions(
    'command=s'          => \$command,
    'ssh_user=s'         => \$ssh_user,
    'orig_master_host=s' => \$orig_master_host,
    'orig_master_ip=s'   => \$orig_master_ip,
    'orig_master_port=i' => \$orig_master_port,
    'new_master_host=s'  => \$new_master_host,
    'new_master_ip=s'    => \$new_master_ip,
    'new_master_port=i'  => \$new_master_port,
);

exit &main();

sub main {
   

    print "\n\nIN SCRIPT TEST====$ssh_stop_vip==$ssh_start_vip===\n\n";

    if ( $command eq "stop" || $command eq "stopssh" ) {
   

        my $exit_code = 1;
        eval {
   
            print "Disabling the VIP on old master: $orig_master_host \n";
            &stop_vip();
            $exit_code = 0;
        };
        if ($@) {
   
            warn "Got Error: $@\n";
            exit $exit_code;
        }
        exit $exit_code;
    }
    elsif ( $command eq "start" ) {
   

        my $exit_code = 10;
        eval {
   
            print "Enabling the VIP - $vip on the new master - $new_master_host \n";
            &start_vip();
            $exit_code = 0;
        };
        if ($@) {
   
            warn $@;
            exit $exit_code;
        }
        exit $exit_code;
    }
    elsif ( $command eq "status" ) {
   
        print "Checking the Status of the script.. OK \n";
        exit 0;
    }
    else {
   
        &usage();
        exit 1;
    }
}

sub start_vip() {
   
    `ssh $ssh_user\@$new_master_host \" $ssh_start_vip \"`;
}
sub stop_vip() {
   
     return 0  unless  ($ssh_user);
    `ssh $ssh_user\@$orig_master_host \" $ssh_stop_vip \"`;
}

sub usage {
   
    print
    "Usage: master_ip_failover --command=start|stop|stopssh|status --orig_master_host=host --orig_master_ip=ip --orig_master_port=port --new_master_host=host --new_master_ip=ip --new_master_port=port\n";
}

2.2.配置MHA指定VIP地址的脚本

需要在MHA的配置文件中指定VIP地址漂移的脚本。

[root@mysql-3 ~]# vim /data/mha/app1.cnf 
[server default]
·····
master_ip_failover_script=/data/mha/scripts/master_ip_failover

#给脚本一个执行权限
[root@mysql-3 ~]# chmod +x /usr/local/bin/master_ip_failover 

2.3.手动在主库上配置VIP地址

第一次配置VIP地址,需要现在主库对应的网卡上配置好VIP地址,否则当故障出现时,VIP地址不能漂移到新的主库,并且还会报错,因为脚本要先删掉主库中的VIP,然后在新的主库上添加,如果一开始就不存在,肯定会报错。

[root@mysql-2 ~]# ifconfig ens192:1 192.168.20.15/23

[root@mysql-2 ~]# ip a
2: ens192: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 00:50:56:b7:eb:68 brd ff:ff:ff:ff:ff:ff
    inet 192.168.20.12/23 brd 192.168.21.255 scope global ens192
       valid_lft forever preferred_lft forever
    inet 192.168.20.15/23 brd 192.168.21.255 scope global secondary ens192:1
       valid_lft forever preferred_lft forever

2.4.重启MHA

[root@mysql-3 ~]# masterha_stop --conf=/data/mha/app1.cnf 
Stopped app1 successfully.
[root@mysql-3 ~]# nohup masterha_manager --conf=/data/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover  < /dev/null> /data/mha/logs/manager.log 2>&1 &

2.5.模拟主库故障观察VIP是否会自动切换

1)模拟主库故障

1.主库是mysql-2
[root@mysql-3 ~]# masterha_check_status --conf=/data/mha/app1.cnf
app1 (pid:13746) is running(0:PING_OK), master:192.168.20.12

2.模拟主库故障
[root@mysql-2 ~]# systemctl stop mysqld

2)观察VIP是否漂移

目前mysql-3成为了主库,VIP也漂移到了mysql-3的服务器中。

[root@mysql-3 ~]# ip a
2: ens192: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 00:50:56:b7:c3:1d brd ff:ff:ff:ff:ff:ff
    inet 192.168.20.13/23 brd 192.168.21.255 scope global ens192
       valid_lft forever preferred_lft forever
    inet 192.168.20.15/23 brd 192.168.21.255 scope global secondary ens192:1
       valid_lft forever preferred_lft forever
    inet6 fe80::250:56ff:feb7:c31d/64 scope link 
       valid_lft forever preferred_lft forever

通过漂移IP连接主库。

[root@mysql-2 ~]# mysql -uroot -p123456 -h 192.168.20.15
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+

相关推荐

  1. 98MHA可用VIP地址配置漂移实践

    2024-02-18 11:36:01       49 阅读
  2. MySQL可用实战(MHA)

    2024-02-18 11:36:01       45 阅读
  3. 基于IvorySQL+Patroni+vip-manager构建可用

    2024-02-18 11:36:01       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-18 11:36:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-18 11:36:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-18 11:36:01       87 阅读
  4. Python语言-面向对象

    2024-02-18 11:36:01       96 阅读

热门阅读

  1. C++单例模式的实现

    2024-02-18 11:36:01       50 阅读
  2. 从数据保护角度考虑防勒索建设

    2024-02-18 11:36:01       55 阅读
  3. Node.js开发-path模块

    2024-02-18 11:36:01       57 阅读
  4. with ThreadPoolExecutor() as executor的使用举例

    2024-02-18 11:36:01       53 阅读
  5. 14 图论

    14 图论

    2024-02-18 11:36:01      53 阅读
  6. android11以上SD卡存储权限适配申请问题

    2024-02-18 11:36:01       51 阅读
  7. gin(结)

    2024-02-18 11:36:01       46 阅读
  8. WebSocket 详细教程

    2024-02-18 11:36:01       43 阅读