Centos7 下 mysql5.7-mmm 高可用群集
admin
2023-04-26 22:22:53
0

Centos7 下 mysql5.7-mmm 高可用群集

MMM介绍

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

实验准备

4台安装mysql5.7服务的设备
1台用来安装mmm的centos7设备

实验步骤

关闭防火墙自启动,以及相关功能和增强性安全功能

 systemctl stop firewalld.service 
 setenforce 0

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

wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

yum -y install epel-release

yum clean all && yum makecache

修改mysql服务器的配置文件

vim /etc/my.cnf
修改mysqld下面的内容
[mysqld]
log_error=/var/lib/mysql/mysql.err
log=/var/lib/mysql/mysql_log.log
log_slow_queries=/var/lib/mysql_slow_queris.log
binlog-ignore-db=mysql,information_schema
character_set_server=utf8
log_bin=mysql_bin
server_id=1
log_slave_updates=true
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1

systemctl restart mysqld

-------没有问题后,把配置文件复制到其它3台数据库服务器上并启动服务器-----

scp /etc/my.cnf root@192.168.100.101:/etc/

scp /etc/my.cnf root@192.168.100.102:/etc/

scp /etc/my.cnf root@192.168.100.103:/etc/
-----注意:配置文件中的server_id 要修改-----

配置主主复制,两台主服务器相互复制

show master status; 
+-------------------+----------+--------------+------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000002 |      339 |              |                  |
+-------------------+----------+--------------+------------------+
1 row in set (0.00 sec)    ##记录日志文件名称和 位置值,在两台主上查看。

----在m1上为m2授予从的权限,在m2上也要为m1授予从的权限---

grant replication slave on *.* to 'replication'@'192.168.100.%' identified by '123456'; ##两台主服务器都执行,从服务器不需要

change master to master_host='192.168.100.101',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=339;

-----注意,在m1上要指定m2上的日志文件名,和位置参数-----在m2上要反过来。

start slave;

show slave status;

    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

-------在另一台主上做----要指定m1的日志和位置参数---
change master to master_host='192.168.100.100',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=339;

start slave;

show slave status;

    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

配置主从复制

change master to master_host='192.168.100.100',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=339;

start slave;

show slave status;

    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

安装MMM

在所有服务器上安装-----注意,epel源要配置好

yum -y install mysql-mmm*

配置mmm

cd /etc/mysql-mmm/

vi mmm_common.conf ##所有主机上都要配置,直接复制多份


    cluster_interface       ens33
    ……
    replication_user        replication
    replication_password    123456
    agent_user              mmm_agent
    agent_password          123456


    ip      192.168.100.100
    mode    master
    peer    db2



    ip      192.168.100.101
    mode    master
    peer    db1



    ip      192.168.100.102
    mode    slave



    ip      192.168.100.103
    mode    slave



    hosts   db1, db2
    ips     192.168.100.200
    mode    exclusive



    hosts   db3, db4
    ips     192.168.100.201, 192.168.100.202
    mode    balanced


scp mmm_common.conf root@192.168.100.100:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.100.101:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.100.102:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.100.103:/etc/mysql-mmm/   ## 复制给mysql服务器

------------------在monitor服务器上配置----
cd /etc/mysql-mmm/ //改密码

vi mmm_mon.conf


    monitor_user        mmm_monitor
    monitor_password    123456


--------------在所有数据库上为mmm_agent授权-----
grant super, replication client, process on *.* to 'mmm_agent'@'192.168.100.%' identified by '123456';

--------------在所有数据库上为mmm_moniter授权-----
grant replication client on *.* to 'mmm_monitor'@'192.168.100.%' identified by '123456';

flush privileges;

---------------修改所有数据库的mmm_agent.conf----

vi /etc/mysql-mmm/mmm_agent.conf

this db1   ##主1 主2 从1 从2  分别为 db{1,2,3,4}

--------------在所有数据库服务器上启动mysql-mmm-agent---

systemctl start mysql-mmm-agent.service
systemctl enable mysql-mmm-agent.service

------------------在monitor服务器上配置------
cd /etc/mysql-mmm/
vi mmm_mon.conf

……
 ping_ips            192.168.100.100,192.168.100.101,192.168.100.102,192.168.100.103 ##数据库服务器地址

 auto_set_online     10

systemctl start mysql-mmm-monitor.service   ##启动mysql-mmm-monitor

 mmm_control show    ##查看各节点的情况
  db1(192.168.100.100) master/ONLINE. Roles: writer(192.168.100.200)
  db2(192.168.100.101) master/ONLINE. Roles: 
  db3(192.168.100.102) slave/ONLINE. Roles: reader(192.168.100.201)
  db4(192.168.100.103) slave/ONLINE. Roles: reader(192.168.100.202)

mmm_control checks all   ## 需要各种OK

mmm_control move_role writer db1   ##手动转换角色

测试

关掉主1 的mysql服务
systemctl stop mysqld
mmm_control show    ##查看各节点的情况
  db1(192.168.100.100) master/HARD_OFFLINE. Roles: 
  db2(192.168.100.101) master/ONLINE. Roles: writer(192.168.100.200)
  db3(192.168.100.102) slave/ONLINE. Roles: reader(192.168.100.201)
  db4(192.168.100.103) slave/ONLINE. Roles: reader(192.168.100.202)

关掉从1的mysql服务
mmm_control show    ##查看各节点的情况
 db1(192.168.100.100) master/HARD_OFFLINE. Roles: 
  db2(192.168.100.101) master/ONLINE. Roles: writer(192.168.100.200)
  db3(192.168.100.102) slave/HARD_OFFLINEE. Roles: 
  db4(192.168.100.103) slave/ONLINE. Roles: reader(192.168.100.201,192.168.100.202)

至此,通过mmm完成mysql高可用群集

相关内容

热门资讯

美媒:中美元首会晤或讨论AI护... 据凤凰卫视援引美国媒体报道,美方希望借中美领导人会晤的机会,开启有关人工智能安全与管控的对话,并推动...
卫生间水管布置图尺寸高度 卫生间的水管布置可能比较复杂一些,因为卫生间的管道比较多。比如有热水器的通水管道,有座便器的冲水管道...
电脑尺寸在哪里看 电脑尺寸在哪里看1、可以选择手工测量法来测量电脑尺寸,这时测量一下屏幕对角线,因为显示面积都会小于显...
电脑机箱尺寸标准 常规的机箱一般是立体式,或桌面式,再就是横式。电脑机箱尺寸,目前市面上根据不同的规格有不同的方案。 ...
斯塔默发声:不会辞职 【环球时报驻英国特约记者 纪双城 环球时报特约记者 甄翔 于文】执政党工党在英国地方选举中遭遇“历史...
抽油烟机管道有异味怎么办 抽油烟机是厨房中不可或缺的设备,它能有效地排出油烟,保证室内空气的清新。但是,长时间使用后,抽油烟机...
抽油烟机管道有油垢怎么办 抽油烟机管道是我们家庭生活中必不可少的设备,但长时间的使用会导致管道内部积累大量的油垢,如不及时清理...
沈伯洋与台北市长格局有落差,叶... 海峡导报综合报道 民进党将正式拍板征召民代沈伯洋出战台北市长,并发布采访通知,预计在13日下午举行台...
核查:上世纪已有多款汉坦疫苗上... 明查员 冯梦速览- 人类感染汉坦病毒已有数十年历史。朝鲜战争期间,联合国军就曾有过大规模感染。汉坦病...
如何从“一证在手”走向“一技傍... 教员在给学员讲解理论知识。 学员在进行无人机试飞训...