MySQL数据库——MMM高可用群集架构

概念

MMM(Master-Master replication managerfor Mysql,Mysql主主复制管理器)是一套灵活的脚本程序,基于perl实现,
用来对mysql replication进行监控和故障迁移,并能管理mysql Master-Master复制的配置(同一时间只有一个节点是可写的)。

MMM高可用架构说明

mmm_mond:监控进程,负责所有的监控工作,决定和处理所有节点角色活动。此脚本需要在监管机上运行。
mmm_agentd:运行在每个mysql服务器上的代理进程,完成监控的探针工作和执行简单的远端服务设置。此脚本需要在被监管机上运行。
mmm_control:一个简单的脚本,提供管理mmm_mond进程的命令。
mysql-mmm的监管端会提供多个虚拟IP(VIP),包括一个可写VIP,多个可读VIP,通过监管的管理,这些IP会绑定在可用mysql之上,当某一台mysql宕机时,监管会将VIP迁移至其他mysql。
    在整个监管过程中,需要在mysql中添加相关授权用户,以便让mysql可以支持监理机的维护。授权的用户包括一个mmm_monitor用户和一个mmm_agent用户。

MMM的优缺点

优点: 高可用性,扩展性好,出现故障自动切换,对于主主同步,在同一时间只提供一台数据库写操作,保证的数据的一致性。
缺点: Monitor节点是单点,可以结合Keepalived实现高可用,对主机的数量有要求,需要实现读写分离,对程序来说是个挑战。

实验环境部署

第一步:在四台服务器上都需要安装MySQL数据库

1.配置ALI云源,然后安装epel-release源

[[email protected] ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

[[email protected] ~]# yum -y install epel-release

[[email protected] ~]# yum clean all && yum makecache

2.搭建本地yum源

#安装数据库
[[email protected] ~]# yum -y install mariadb-server mariadb

#关闭防火墙和安全功能
[[email protected] ~]# systemctl stop firewalld.service
[[email protected] ~]# setenforce 0

#开启数据库
[[email protected] ~]# systemctl start mariadb.service

3.修改ml主配置文件

[[email protected] ~]# vim /etc/my.cnf
#删除前9行,添加以下内容
[mysqld]
log_error=/var/lib/mysql/mysql.err          #错误日志的文件位置
log=/var/lib/mysql/mysql_log.log            #访问日志的文件位置
log_slow_queries=/var/lib/mysql_slow_queris.log         #man日志的文件位置
binlog-ignore-db=mysql,information_schema          #mysql,information_schema不生成二进制日志文件
character_set_server=utf8               #字符集
log_bin=mysql_bin             #二进制日志文件功能开启
server_id=1               #不同主机id不同
log_slave_updates=true              #授权同步
sync_binlog=1               #二进制日志文件功能开启
auto_increment_increment=2              #自增量
auto_increment_offset=1                 #起始值

[[email protected] ~]# systemctl restart mariadb.service
[[email protected] ~]# netstat -natp | grep 3306

4.复制配置文件到其他三台数据库服务器,注意修改server_id

[[email protected] ~]# scp /etc/my.cnf [email protected]:etc/

5.进入数据库,并查看日志文件信息

[[email protected] ~]# mysql

#查看记录日志文件名称和位置值
MariaDB [(none)]> show master status;
+------------------+----------+--------------+--------------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB         |
+------------------+----------+--------------+--------------------------+
| mysql_bin.000001 |       245|              | mysql,information_schema |
+------------------+----------+--------------+--------------------------+
1 row in set (0.00 sec)

6.在m1和m2上互相授予访问的权限,并授权同步日志

#在m1和m2上互相授予访问的权限
MariaDB [(none)]> grant replication slave on *.* to ‘replication‘@‘192.168.142.%‘ identified by ‘123456‘;

#在m1上指定m2的日志文件名和位置参数
MariaDB [(none)]> change master to master_host=‘192.168.142.134‘,master_user=‘replication‘,master_password=‘123456‘,master_log_file=‘mysql_bin.000001‘,master_log_pos=245;

#在m2上指定m1的日志文件名和位置参数
MariaDB [(none)]> change master to master_host=‘192.168.142.131‘,master_user=‘replication‘,master_password=‘123456‘,master_log_file=‘mysql_bin.000001‘,master_log_pos=245;

7.在m1上开启同步功能

MariaDB [(none)]> start slave;

8.查看同步状态,两台主服务器都要看到Yes

MariaDB [(none)]> show slave status\G;

             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

9.在m1上创建数据库

MariaDB [(none)]> create database school; 

10.在m2上查看同步数据库

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| school             |
| test               |
+--------------------+
5 rows in set (0.00 sec)

11.在两台从上做-注意日志文件和位置参数的改变(都指向m1)

MariaDB [(none)]> change master to master_host=‘192.168.142.131‘,master_user=‘replication‘,master_password=‘123456‘,master_log_file=‘mysql_bin.000001‘,master_log_pos=245;

12.开启同步功能

MariaDB [(none)]> start slave;

#在从服务器上查看同步数据信息
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| school             |
| test               |
+--------------------+
5 rows in set (0.00 sec)

13.在四台服务器上安装MMM相关软件

[[email protected] ~]# yum -y install mysql-mmm*

14.配置mmm_common.conf配置文件

[[email protected] ~]# vim /etc/mysql-mmm/mmm_common.conf

<host default>
#修改网卡为ens33
    cluster_interface       ens33
    pid_path                /run/mysql-mmm-agent.pid
    bin_path                /usr/libexec/mysql-mmm/
    replication_user        replicantion

    #修改授权密码
    replication_password    123456
    agent_user              mmm_agent

    #修改代理授权密码
    agent_password          123456
</host>

#指定四台服务器的角色与IP地址
<host db1>
    ip      192.168.142.131
    mode    master
    peer    db2
</host>

<host db2>
    ip      192.168.142.134
    mode    master
    peer    db1
</host>

<host db3>
    ip      192.168.142.130
    mode    slave
</host>

<host db4>
    ip      192.168.142.135
    mode    slave
</host>

#设定主服务器虚拟IP
<role writer>
    hosts   db1, db2
    ips     192.168.142.250
    mode    exclusive
</role>

#设定从服务器虚拟IP
<role reader>
    hosts   db3, db4
    ips     192.168.142.251, 192.168.142.252
    mode    balanced
</role>

15.从m1上面复制配置文件到其他三台服务器

[[email protected] ~]# scp mmm_common.conf/mmm_common.conf [email protected]:/etc/mysql-mmm/mmm_common.conf
[[email protected] ~]# scp mmm_common.conf/mmm_common.conf [email protected]:/etc/mysql-mmm/mmm_common.conf
[[email protected] ~]# scp mmm_common.conf/mmm_common.conf [email protected]:/etc/mysql-mmm/mmm_common.conf

第二步:配置monitor监控服务器

1.安装epel-release源以及MMM相关软件

[[email protected] ~]# systemctl stop firewalld.service
[[email protected] ~]# setenforce 0
[[email protected] ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
[[email protected] ~]# yum -y install epel-release
[[email protected] ~]# yum clean all && yum makecache
[[email protected] ~]# yum -y install mysql-mmm*

2.从m1上面复制配置文件到监控服务器

[[email protected] ~]# scp mmm_common.conf [email protected]:/etc/mysql-mmm/

3.配置mmm_common.conf配置文件

[[email protected] ~]# vim /etc/mysql-mmm/mmm_mon.conf

<monitor>
    ip                  127.0.0.1
    pid_path            /run/mysql-mmm-monitor.pid
    bin_path            /usr/libexec/mysql-mmm
    status_path         /var/lib/mysql-mmm/mmm_mond.status

    #指向四台服务器的IP地址
    ping_ips            192.168.142.131,192.168.142.134,192.168.142.130,192.168.142.135
    auto_set_online     10

4.在所有数据库服务器上为mmm_agent授权

MariaDB [(none)]> grant super, replication client, process on *.* to ‘mmm_agent‘@‘192.168.142.%‘ identified by ‘123456‘;
Query OK, 0 rows affected (0.02 sec)

5.在所有数据库服务器上为mmm_moniter授权

MariaDB [(none)]> grant replication client on *.* to ‘mmm_monitor‘@‘192.168.18.%‘ identified by ‘123456‘;
Query OK, 0 rows affected (0.02 sec)

6.刷新数据库、在所有数据库服务器上设定代理名称

[[email protected] ~]# vim /etc/mysql-mmm/mmm_agent.conf   #修改代理配置文件
#m1中默认名称
this db1 

#m2中名称
this db2

#s1中名称
this db3

#s2中名称
this db4

7.所有数据库服务器上启动代理功能并设定开机自启动

#启动代理功能
[[email protected] ~]# systemctl start mysql-mmm-agent.service

#设置开机自启动
[[email protected] ~]# systemctl enable mysql-mmm-agent.service   

8.在monitor服务器开启监控服务、查看各节点的情况

[[email protected] mysql-mmm]# systemctl start mysql-mmm-monitor.service
[[email protected] ~]# mmm_control show
  db1(192.168.142.131) master/ONLINE. Roles: writer(192.168.142.250)
  db2(192.168.142.134) master/ONLINE. Roles:
  db3(192.168.142.130) slave/ONLINE. Roles: reader(192.168.142.252)
  db4(192.168.142.135) slave/ONLINE. Roles: reader(192.168.142.251)

9、检测所有服务器状态

[[email protected] ~]# mmm_control checks all
db4  ping         [last change: 2019/11/25 18:23:03]  OK
db4  mysql        [last change: 2019/11/25 18:23:03]  OK
db4  rep_threads  [last change: 2019/11/25 18:23:03]  OK
db4  rep_backlog  [last change: 2019/11/25 18:23:03]  OK: Backlog is null
db2  ping         [last change: 2019/11/25 18:23:03]  OK
db2  mysql        [last change: 2019/11/25 18:59:01]  OK
db2  rep_threads  [last change: 2019/11/25 18:59:01]  OK
db2  rep_backlog  [last change: 2019/11/25 18:59:01]  OK: Backlog is null
db3  ping         [last change: 2019/11/25 18:23:03]  OK
db3  mysql        [last change: 2019/11/25 18:59:01]  OK
db3  rep_threads  [last change: 2019/11/25 18:59:01]  OK
db3  rep_backlog  [last change: 2019/11/25 18:59:01]  OK: Backlog is null
db1  ping         [last change: 2019/11/25 18:23:03]  OK
db1  mysql        [last change: 2019/11/25 18:59:01]  OK
db1  rep_threads  [last change: 2019/11/25 18:59:01]  OK
db1  rep_backlog  [last change: 2019/11/25 18:59:01]  OK: Backlog is null

第三、故障测试

1、模拟m1服务器宕机,停止服务

[[email protected] ~]# systemctl stop mariadb.service

2.当m1服务器宕机后,m2接收虚拟IP继续提供服务

[[email protected] ~]# mmm_control show
  db1(192.168.142.131) master/ONLINE. Roles:
  db2(192.168.142.134) master/ONLINE. Roles: writer(192.168.142.250)
  db3(192.168.142.130) slave/ONLINE. Roles: reader(192.168.142.252)
  db4(192.168.142.135) slave/ONLINE. Roles: reader(192.168.142.251)

3.当s1服务器宕机后,s2接收虚拟IP继续提供服务

[[email protected] ~]# mmm_control show db1(192.168.142.131) master/ONLINE. Roles: writer(192.168.142.250)
db2(192.168.142.134) master/ONLINE. Roles:
db3(192.168.142.130) slave/HARD_OFFLINE. Roles:
db4(192.168.142.135) slave/ONLINE. Roles: reader(192.168.142.251), reader(192.168.142.252

4.在m1服务器上为监控服务器地址授权登录

MariaDB [(none)]> grant all on *.* to ‘root‘@‘192.168.142.136‘ identified by ‘123456‘;
Query OK, 0 rows affected (0.00 sec)

5.在监控服务器上安装数据库客户端

[[email protected] ~]# yum -y install mariadb 

6.在监控服务器上使用指定用户登录数据库,并创建数据信息

[[email protected] ~]# mysql -u root -p -h 192.168.142.250
Enter password:
#输入密码即可

#创建一个数据库
MariaDB [(none)]> create database BDQN;
Query OK, 1 row affected (0.01 sec)

7.在所有数据库上都能查看及时同步到的数据信息

MariaDB [(none)]> show databases;   #查看数据库
+--------------------+
| Database           |
+--------------------+
| information_schema |
| BDQN               |          #同步到的BDQN数据库
| mysql              |
| performance_schema |
| school             |
| test               |
+--------------------+
6 rows in set (0.00 sec)

到此MMM群集架构已完成,谢谢阅读!!!

原文地址:https://blog.51cto.com/14475593/2455859

时间: 2024-10-11 12:10:40

MySQL数据库——MMM高可用群集架构的相关文章

MySQL数据库——MMM高可用群集配置(实战!)

MMM简介 MMM(Master-Master replication manager for MySQL)是一套支持双主故障切换和双主日常管理的脚本程序.MMM使用Perl语言开发,主要用来监控和管理MySQL Master-Master(双主)复制,可以说是mysql主主复制管理器.虽然叫做双主复制,但是业务上同一时刻只允许对一个主进行写入,另一台备选主上提供部分读服务,以加速在主主切换时刻备选主的预热,可以说MMM这套脚本程序一方面实现了故障切换的功能,另一方面其内部附加的工具脚本也可以实

MySQL数据库---MHA高可用群集架构

MHA概述 日本DeNA公司youshimaton (现就职于Facebook公司) 开发 一套优秀的作为MySQL高可用性环境下故障切换和主从提升的高可用软件 MHA的组成 MHA Manager (管理节点) MHA Node (数据节点) MHA特点 自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据的不丢失 使用MySQL 5.5的半同步复制,可以大大降低数据丢失的风险 实验思路 1.MHA架构 (1)数据库安装 (2)一主两从 (3)MHA搭建 2.故障

MySQL数据库的优化(下)MySQL数据库的高可用架构方案

MySQL数据库的优化(下)MySQL数据库的高可用架构方案 2011-03-09 08:53 抚琴煮酒 51CTO 字号:T | T 在上一篇MySQL数据库的优化中,我们跟随笔者学习了单机MySQL数据库的优化,今天我们继续跟随笔者学习MySQL优化的集群方案. AD:51CTO 网+首届APP创新评选大赛火热启动——超百万资源等你拿! [51CTO独家特稿]在上一篇MySQL数据库的优化中,我们跟随笔者学习了单机MySQL数据库的优化,今天我们继续跟随笔者学习MySQL优化的集群方案. M

基于mysql-mmm实现MySQL数据库的高可用

MMM简介 MMM(Master-Master Replication Manager for MySQL)MySQL主主复制管理器,实现了对MySQL双主复制架构的监控,故障转移和管理.mysql-mmm在实现过程中提供了多个虚拟IP,包括用于写操作的虚拟IP和用于读操作的虚拟IP.在双主复制架构中仅有其中的一台主节点可用于写操作,所有节点包括从节点对外提供读操作.当其中的一个从节点故障时,它持有的虚拟IP会自动转移至其他节点上.若故障的是主节点,它持有的写操作的虚拟IP和读操作的虚拟IP都会

MySQL数据库——MHA高可用集群架构(实战!!!)

MHA 简介 (1)简介 目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是一套优秀的作为MySQL高可用性环境下故障切换和主从提升的高可用软件.在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,以达到真正意义上的高可用. (2)该软件由两部分组成 MHA Manager(管理节点)和MHA Node(数据节点)

MMM高可用群集

MMM概述 MMM(Master-Master replication manager for MySQL)是一套支持双主故障切换和双主日常管理的脚本程序.MMM使用Perl语言开发,主要用来监控和管理MySQL Master-Master(双主)复制,可以说是mysql主主复制管理器.虽然叫做双主复制,但是业务上同一时刻只允许对一个主进行写入,另一台备选主上提供部分读服务,以加速在主主切换时刻备选主的预热,可以说MMM这套脚本程序一方面实现了故障切换的功能,另一方面其内部附加的工具脚本也可以实

mysql之MMM高可用方案简介

MMM(Master-Master Replication Manager for MySQL) MySQL主主复制管理器,提供了MySQL主主复制配置的监控.故障转移和管理的一套可伸缩的脚本套件.在MMM高可用解决方案中,典型的应用是双主多从架构,通过MySQL replication技术可以实现两台服务器互为主从,且在任何时候只有一个节点可以写入,避免多点写入的数据冲突.同时,当可写的主节点故障时,MMM套件可以立刻监控到,然后将服务自动切换到另一个主节点,继续提供服务,从而实现MySQL的

mysql的MMM高可用方案

1    MMM高可用mysql方案 1.1  方案简介 MMM即Master-Master Replication Manager for MySQL(mysql主主复制管理器)关于mysql主主复制配置的监控.故障转移和管理的一套可伸缩的脚本套件(在任何时候只有一个节点可以被写入),这个套件也能对居于标准的主从配置的任意数量的从服务器进行读负载均衡,所以你可以用它来在一组居于复制的服务器启动虚拟ip,除此之外,它还有实现数据备份.节点之间重新同步功能的脚本.MySQL本身没有提供replic

Mysql数据库实现高可用

Mysql实现高可用 MMM MMM(master-master replication manager for mysql)mysql主主复制管理器. MMM是一套灵活的脚本程序,基于perl实现,用来对mysql replication进行监控和故障迁移,并能管理mysql master-master复制的配置(同一时间只有一个节点是可写的). MMM的监管端是会提供多个虚拟ip(vip),包括一个可写的vip,多个可读的vip,通过监管的管理,这些ip会绑定在可用的mysql上,当某一台m