千家信息网

MySQL中MMM高可用架构的安装配置流程

发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,下文我给大家简单讲讲关于MySQL中MMM高可用架构的安装配置流程,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完MySQL中MMM高可用架构的安装配置流程对大家多少有点
千家信息网最后更新 2025年01月21日MySQL中MMM高可用架构的安装配置流程

下文我给大家简单讲讲关于MySQL中MMM高可用架构的安装配置流程,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完MySQL中MMM高可用架构的安装配置流程对大家多少有点帮助吧。

实验环境

主机IP地址
mysql-m1主云服务器192.168.58.131
mysql-m2主云服务器192.168.58.136
mysql-m3从云服务器192.168.58.146
mysql-m4从云服务器192.168.58.147
mysql-monitor监视代理云服务器192.168.58.148

实验过程

搭建MySQL多主多从模式

1、在四台MySQL云服务器上,都安装MySQL,过程省略

2、配置ALI云源,然后安装epel-rlease源,为了下面安装mysql-mmm工具套件。

[root@localhost ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo[root@localhost ~]# yum -y install epel-release[root@localhost ~]# yum clean all && yum makecache

3、配置修改m1主配置文件。

vim /etc/my.cnf [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                                      #开启binlog日志用于主从数据复制server_id=1                                            #每台server-id的值不能一样log_slave_updates=true                                 #此数据库宕机,备用数据库接管sync_binlog=1                                          #允许同步二进制日志auto_increment_increment=2                             #字段依次递增多少auto_increment_offset=1                                #自增字段的起始值:1、3、5等奇数ID

配置没问题后,把配置文件复制到另外一台主云服务器

[root@localhost ~]# scp /etc/my.cnf root@192.168.58.136:/etc/

4、配置mysql-m1、mysql-m2主主模式
首先查看log bin日志和pos值的位置。

[root@localhost1 ~]# mysqlWelcome to the MariaDB monitor.  Commands end with ; or \g.Your MySQL connection id is 1065Server version: 5.5.24-log Source distributionCopyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MySQL [(none)]> show master status;+------------------+----------+--------------+--------------------------+| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB         |+------------------+----------+--------------+--------------------------+| mysql_bin.000002 |      107 |              | mysql,information_schema |+------------------+----------+--------------+--------------------------+1 row in set (0.00 sec)[root@localhost2 ~]# mysqlWelcome to the MariaDB monitor.  Commands end with ; or \g.Your MySQL connection id is 1065Server version: 5.5.24-log Source distributionCopyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MySQL [(none)]> show master status;+------------------+----------+--------------+--------------------------+| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB         |+------------------+----------+--------------+--------------------------+| mysql_bin.000002 |      107 |              | mysql,information_schema |+------------------+----------+--------------+--------------------------+1 row in set (0.00 sec)

然后,mysql-m1、mysql-m2互相提升访问权限。

mysql-m1MySQL [(none)]> grant replication slave on *.* to 'replication'@'192.168.58.%' identified by '123456'; MySQL [(none)]> change master to master_host='192.168.58.136',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=107;MySQL [(none)]> flush privileges;mysql-m2MySQL [(none)]> grant replication slave on *.* to 'replication'@'192.168.58.%' identified by '123456'; MySQL [(none)]> change master to master_host='192.168.58.131',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=107;MySQL [(none)]> flush privileges;

最后分别查看mysql-m1、mysql-m2云服务器的主从状态,主要查看

Slave_IO_Running: Yes

Slave_SQL_Running: Yes。

MySQL [(none)]> start slave;MySQL [(none)]> show slave status\G;*************************** 1. row ***************************               Slave_IO_State: Waiting for master to send event                  Master_Host: 192.168.58.131                  Master_User: replication                  Master_Port: 3306                Connect_Retry: 60              Master_Log_File: mysql_bin.000002          Read_Master_Log_Pos: 107               Relay_Log_File: localhost-relay-bin.000012                Relay_Log_Pos: 253        Relay_Master_Log_File: mysql_bin.000002             Slave_IO_Running: Yes            Slave_SQL_Running: Yes

说明主主同步配置成功。
测试主主同步,在mysql-m1新建一个库test01

mysql-m1MySQL [(none)]> create database test01;MySQL [(none)]> show databases;+--------------------+| Database           |+--------------------+| information_schema || #mysql50#.mozilla  || bbs                || mysql              || performance_schema || test               || test01             |+--------------------+7 rows in set (0.22 sec)mysql-m2                                #测试成功MySQL [(none)]> show databases;+--------------------+| Database           |+--------------------+| information_schema || #mysql50#.mozilla  || mysql              || performance_schema || test               || test01             |+--------------------+7 rows in set (0.22 sec)

5、配置myqsl-m3、mysql-m4作为mysql-m1的从库。

首先将mysql-m1上的/etc/my.cnf文件,复制到myqsl-m3、mysql-m4两台云服务器上。

mysql-m1[root@localhost ~]# scp /etc/my.cnf root@192.168.58.146:/etc/[root@localhost ~]# scp /etc/my.cnf root@192.168.58.147:/etc/

查看mysql-m1中数据库的状态值。

MySQL [(none)]> show master status;+------------------+----------+--------------+--------------------------+| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB         |+------------------+----------+--------------+--------------------------+| mysql_bin.000002 |      107 |              | mysql,information_schema |+------------------+----------+--------------+--------------------------+1 row in set (0.00 sec)

在mysql-m3、mysql-m4上分别执行。

mysql-m3MySQL [(none)]> change master to master_host='192.168.58.131',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=107;mysql-m4MySQL [(none)]> change master to master_host='192.168.58.131',master_user='replication',master_password='123456',master_log_file='mysql_bin.000002',master_log_pos=107;

分别查看mysql-m3、mysql-m4云服务器的主从状态,如下所示。

MySQL [(none)]> show slave status\G;*************************** 1. row ***************************               Slave_IO_State: Waiting for master to send event                  Master_Host: 192.168.58.131                  Master_User: replication                  Master_Port: 3306                Connect_Retry: 60              Master_Log_File: mysql_bin.000002          Read_Master_Log_Pos: 107               Relay_Log_File: localhost-relay-bin.000012                Relay_Log_Pos: 253        Relay_Master_Log_File: mysql_bin.000002             Slave_IO_Running: Yes            Slave_SQL_Running: Yes

安装配置MySQL-MMM

CentOS默认没有mysql-mmm软件包,由于之前我们epel官方源已经安装好,在五台主机上都要安装MMM

[root@localhost ~]# yum -y install mysql-mmm*

安装完后,对MMM进行配置

[root@localhost mongodb1]# vim /etc/mysql-mmm/mmm_common.conf     cluster_interface       ens33                       #网卡名称    ……    replication_user        replication    replication_password    123456    agent_user              mmm_agent    agent_password          123456    ip      192.168.58.131    mode    master    peer    db2    ip      192.168.58.136    mode    master    peer    db1    ip      192.168.58.146    mode    slave    ip      192.168.58.147    mode    slave    hosts   db1, db2    ips     192.168.58.100    mode    exclusive    hosts   db3, db4    ips     192.168.58.200, 192.168.58.210    mode    balanced                   #将配置文件复制到其他几台数据库云服务器对应的目录下[root@localhost mysql-mmm]# scp mmm_common.conf root@192.168.58.136:/etc/mysql-mmm/[root@localhost mysql-mmm]# scp mmm_common.conf root@192.168.58.146:/etc/mysql-mmm/[root@localhost mysql-mmm]# scp mmm_common.conf root@192.168.58.147:/etc/mysql-mmm/[root@localhost mysql-mmm]# scp mmm_common.conf root@192.168.58.148:/etc/mysql-mmm/

在作为monitor云服务器的终端上配置

cd /etc/mysql-mmm/ #改密码vim mmm_mon.conf    monitor_user        mmm_monitor    monitor_password    123456

在所有数据库上为mmm_agent授权

MySQL [(none)]> grant super, replication client, process on *.* to 'mmm_agent'@'192.168.58.%' identified by '123456';#为mmm_agent授权

在所有数据库上为mmm_moniter授权

MySQL [(none)]> grant replication client on *.* to 'mmm_monitor'@'192.168.58.%' identified by '123456';#为mmm_monitor授权MySQL [(none)]> flush privileges#刷新权限设置

修改所有数据库的mmm_agent.conf

[root@localhost mysql-mmm]# vim /etc/mysql-mmm/mmm_agent.confinclude mmm_common.conf# The 'this' variable refers to this server.  Proper operation requires# that 'this' server (db1 by default), as well as all other servers, have the# proper IP addresses set in mmm_common.conf.this db1        #分别在四台数据库云服务器上设置为db1,db2,db3,db4~                  

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

[root@localhost mysql-mmm]# systemctl start mysql-mmm-agent.service#启动mmm-agent服务[root@localhost mysql-mmm]# systemctl enable mysql-mmm-agent.service#设置mmm-agent服务开机启动

在monitor云服务器上配置

[root@localhost mysql-mmm]# cd /etc/mysql-mmm/[root@localhost mysql-mmm]# vim mmm_mon.conf     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    ping_ips            192.168.58.131,192.168.58.136,192.168.58.146,192.168.58.147    #指定监管的云服务器IP地址    auto_set_online     10    # The kill_host_bin does not exist by default, though the monitor will    # throw a warning about it missing.  See the section 5.10 "Kill Host    # Functionality" in the PDF documentation.    #    # kill_host_bin     /usr/libexec/mysql-mmm/monitor/kill_host    #    monitor_user        mmm_monitor   #设置监管账户    monitor_password    123456        #设置监管密码[root@localhost mysql-mmm]# systemctl start mysql-mmm-monitor.service   #启动mysql-mmm-monitor[root@localhost mysql-mmm]# mmm_control show   #查看节点运行情况  db1(192.168.58.131) master/ONLINE. Roles: writer(192.168.58.100)  db2(192.168.58.136) master/ONLINE. Roles:   db3(192.168.58.146) slave/ONLINE. Roles: reader(192.168.58.200)  db4(192.168.58.147) slave/ONLINE. Roles: reader(192.168.58.210)

当我们把mysql-m3的mysql服务停掉以后,对应的VIP会自动绑定到mysql-m4上

[root@localhost mysql-mmm]# mmm_control show     db1(192.168.58.131) master/ONLINE. Roles: writer(192.168.58.100)  db2(192.168.58.136) master/ONLINE. Roles:   db3(192.168.58.146) slave/HARD_OFFLINE. Roles:
db4(192.168.58.147) slave/ONLINE. Roles: reader(192.168.58.210)(192.168.58.200)

大家觉得MySQL中MMM高可用架构的安装配置流程这篇文章怎么样,是否有所收获。如果想要了解更多相关,可以继续关注我们的行业资讯板块。
0