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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介:

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


实验架构图:

wKioL1SbeqHyGF7WAAEGk3sODA4346.jpg


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

wKioL1SbgXOzyPF5AAB3PKq6Os0325.jpg

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

wKioL1SbhH3QdWdOAAJBhRl9pYM736.jpg

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

wKioL1SbhRaxVtc5AAB3PKq6Os0925.jpg

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

wKiom1SbhjPxUXBjAAKZv1_WjLU955.jpg

从状态看出复制服务运行正常,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数据库端口,用户名,密码即可直接使用。


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

wKiom1Sbn_GiqrKRAAEysQybBKs065.jpg

使用以下命令可以解决:

# 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

wKiom1SbknvxkZ91AAIARvzmG7A712.jpg


wKiom1SbktvS-2H9AAFtIG96YV8466.jpg

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


wKioL1SbnSmxn-3_AAHGuMxOX0Q529.jpg


测试故障转移

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

wKiom1Sbngrx37kTAAFswoBFAF8765.jpg

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


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

wKiom1SbnyHDj4vzAAItp-PDPKE779.jpg


实验完成!


本文转自qw87112 51CTO博客,原文链接:http://blog.51cto.com/tchuairen/1595801


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
3月前
|
SQL Oracle 关系型数据库
MySQL的sql_mode模式说明及设置
MySQL的sql_mode模式说明及设置
570 112
|
2月前
|
运维 监控 关系型数据库
MySQL高可用方案:MHA与Galera Cluster对比
本文深入对比了MySQL高可用方案MHA与Galera Cluster的架构原理及适用场景。MHA适用于读写分离、集中写入的场景,具备高效写性能与简单运维优势;而Galera Cluster提供强一致性与多主写入能力,适合对数据一致性要求严格的业务。通过架构对比、性能分析及运维复杂度评估,帮助读者根据自身业务需求选择最合适的高可用方案。
|
2月前
|
SQL 监控 关系型数据库
MySQL主从复制:构建高可用架构
本文深入解析MySQL主从复制原理与实战配置,涵盖复制架构、监控管理、高可用设计及性能优化,助你构建企业级数据库高可用方案。
|
存储 SQL 关系型数据库
Mysql高可用架构方案
本文阐述了Mysql高可用架构方案,介绍了 主从模式,MHA模式,MMM模式,MGR模式 方案的实现方式,没有哪个方案是完美的,开发人员在选择何种方案应用到项目中也没有标准答案,合适的才是最好的。
875 3
Mysql高可用架构方案
|
6月前
|
存储 关系型数据库 MySQL
【赵渝强老师】OceanBase数据库从零开始:MySQL模式
《OceanBase数据库从零开始:MySQL模式》是一门包含11章的课程,涵盖OceanBase分布式数据库的核心内容。从体系架构、安装部署到租户管理、用户安全,再到数据库对象操作、事务与锁机制,以及应用程序开发、备份恢复、数据迁移等方面进行详细讲解。此外,还涉及连接路由管理和监控诊断等高级主题,帮助学员全面掌握OceanBase数据库的使用与管理。
329 5
|
9月前
|
监控 关系型数据库 MySQL
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
|
SQL 关系型数据库 MySQL
MySQL的match WITH QUERY EXPANSION 模式是什么?如何使用?
【8月更文挑战第29天】MySQL的match WITH QUERY EXPANSION 模式是什么?如何使用?
219 5
|
2月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
112 3
|
2月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
2月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。

推荐镜像

更多