• Mysql MMM


    MMM概述

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

    MMM提供了自动和手动两种方式移除一组服务器中复制延迟较高的服务器的虚拟ip,同时它还可以备份数据,实现两节点之间的数据同步等。由于MMM无法完全保证数据的一致性,所以MMM适用于对数据的一致性要求不是很高,但是又想最大程度地保证业务可用性的场景。

    MMM是一套灵活的脚本程序,基于perl实现,用来对 mysql replication 进行监控和故障迁移,并能管理 MySQL Master-Master 复制的配置。

    关于 MMM 高可用架构的说明如下:
    ●mmm_mon:监控进程,负责所有的监控工作,决定和处理所有节点角色活动。此脚本需要在监控主机上运行。
    ●mmm_agent:运行在每个MySQL服务器上的代理进程,完成监控的探针工作和执行简单的远端服务设置。此脚本需要在被监管机上运行。
    ●mmm_control:一个简单的脚本,提供管理 mmm_mon 进程的命令。
    ●mysql-mmm 的监管端会提供多个虚拟 IP(VIP),包括一个可写 VIP,多个可读 VIP,通过监管的管理,这些 IP 会绑定在可用 MySQL 之上,当某一台 MySQL 宕机时,监管会将 VIP 迁移至其他 MySQL。

    在整个监管过程中,需要在 MySQL 中添加相关授权用户,以便让 MySQL 可以支持监控主机的维护。 授权的用户包括一个 mmm_monitor 用户和一个 mmm_agent 用户。

    搭建Mysql MMM

    1. 实验配置:
    2. master01:20.0.0.81
    3. master02:20.0.0.82
    4. slave01:20.0.0.83
    5. salve02:20.0.0.84
    6. monitor:20.0.0.10

    1.关闭防火墙

    1. systemctl stop firewalld
    2. setenforce 0

    2.搭建Mysql多主多从模式

    1. //修改 master01 配置文件
    2. vim /etc/my.cnf
    3. ......
    4. [mysqld]
    5. user = mysql
    6. basedir = /usr/local/mysql
    7. datadir = /usr/local/mysql/data
    8. port = 3306
    9. character_set_server=utf8
    10. pid-file = /usr/local/mysql/mysqld.pid
    11. socket = /usr/local/mysql/mysql.sock
    12. server-id = 1 #每台 Mysql 主机的 server-id 不能相同
    13. log-error=/usr/local/mysql/data/mysql_error.log #错误日志
    14. general_log=ON #通用查询日志
    15. general_log_file=/usr/local/mysql/data/mysql_general.log
    16. slow_query_log=ON #慢查询日志
    17. slow_query_log_file=mysql_slow_query.log
    18. long_query_time=5
    19. binlog-ignore-db=mysql,information_schema #不需要同步的库名
    20. log_bin=mysql_bin #开启二进制日志用于主从数据复制
    21. log_slave_updates=true #允许slave从master复制数据时可以写入到自己的二进制日志
    22. sync_binlog=1 #"双1设置",MySQL 在每写一次二进制日志时都会同步到磁盘中去
    23. innodb_flush_log_at_trx_commit=1 #"双1设置",每次事务提交时MySQL都会把缓存的数据写入日志文件,并且刷到磁盘中去
    24. auto_increment_increment=2 #自增字段一次递增多少
    25. auto_increment_offset=1 #自增字段的起始值
    26. ......
    27. //把配置文件复制到其它 3 台数据库服务器上并启动服务器,注意:配置文件中的 server_id 要修改
    28. scp /etc/my.cnf root@20.0.0.82:/etc/
    29. scp /etc/my.cnf root@20.0.0.83:/etc/
    30. scp /etc/my.cnf root@20.0.0.84:/etc/
    31. systemctl restart mysqld
    1. //配置主主复制,两台主服务器相互复制
    2. #在两台主服务器上都执行授予从的权限,从服务器上不需要执行
    3. grant replication slave on *.* to 'replication'@'20.0.0.%' identified by '123456';
    4. #在两台主服务器上查看,记录日志文件名称和同步点
    5. show master status;

    1. #在 master01 上配置同步
    2. change master to master_host='20.0.0.82',master_user='replication',master_password='123456',master_log_file='mysql_bin.000001',master_log_pos=456;
    3. start slave;
    4. show slave status\G
    5. Slave_IO_Running: Yes
    6. Slave_SQL_Running: Yes
    7. #在 master02 上配置同步
    8. change master to master_host='20.0.0.81',master_user='replication',master_password='123456',master_log_file='mysql_bin.000001',master_log_pos=456;
    9. start slave;
    10. show slave status\G
    11. Slave_IO_Running: Yes
    12. Slave_SQL_Running: Yes
    13. //配置主从复制,在两台从服务器上做
    14. change master to master_host='20.0.0.81',master_user='replication',master_password='123456',master_log_file='mysql_bin.000001',master_log_pos=456;
    15. start slave;
    16. show slave status\G
    17. Slave_IO_Running: Yes
    18. Slave_SQL_Running: Yes
    19. //测试主主、主从 同步情况
    20. create database db_test;

    3.安装配置Mysql MMM

    1. //在所有服务器上安装 MySQL-MMM
    2. wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
    3. yum -y install epel-release
    4. yum -y install mysql-mmm*
    5. //在 master01 上对 MySQL-MMM 进行配置
    6. cd /etc/mysql-mmm/
    7. vim mmm_common.conf
    8. ……
    9. <host default>
    10. cluster_interface ens33
    11. ……
    12. replication_user replication
    13. replication_password 123456
    14. agent_user mmm_agent
    15. agent_password 123456
    16. <host db1>
    17. ip 20.0.0.81
    18. mode master
    19. peer db2
    20. </host>
    21. <host db2>
    22. ip 20.0.0.82
    23. mode master
    24. peer db1
    25. </host>
    26. <host db3>
    27. ip 20.0.0.83
    28. mode slave
    29. </host>
    30. <host db4>
    31. ip 20.0.0.84
    32. mode slave
    33. </host>
    34. <role writer>
    35. hosts db1, db2
    36. ips 20.0.0.188
    37. mode exclusive #只有一个 host 可以进行写操作模式
    38. </role>
    39. <role reader>
    40. hosts db3, db4
    41. ips 20.0.0.198, 20.0.0.199
    42. mode balanced #多个 slave 主机可以进行读操作模式
    43. </role>
    44. //把配置文件复制到其它 4 台主机,所有主机该配置文件内容都是一样的
    45. scp mmm_common.conf root@20.0.0.82:/etc/mysql-mmm/
    46. scp mmm_common.conf root@20.0.0.83:/etc/mysql-mmm/
    47. scp mmm_common.conf root@20.0.0.84:/etc/mysql-mmm/
    48. scp mmm_common.conf root@20.0.0.10:/etc/mysql-mmm/
    49. //修改所有数据库服务器的代理配置文件 mmm_agent.conf
    50. vim /etc/mysql-mmm/mmm_agent.conf
    51. include mmm_common.conf
    52. this db1 #根据不同的主机分别修改为 db1,db2,db3,db4
    53. //在 monitor 监控服务器上修改监控配置文件 mmm_mon.conf
    54. vim /etc/mysql-mmm/mmm_mon.conf
    55. include mmm_common.conf
    56. <monitor>
    57. .....
    58. ping_ips 20.0.0.81,20.0.0.82,20.0.0.83,20.0.0.84 #指定所有数据库服务器的 IP
    59. auto_set_online 10 #指定自动上线时间
    60. </monitor>
    61. <host default>
    62. monitor_user mmm_monitor #指定 mmm_monitor 的用户名
    63. monitor_password 123456 #指定 mmm_monitor 的密码
    64. </host>
    65. //在所有数据库上为 mmm_agent(代理进程)授权
    66. grant super, replication client, process on *.* to 'mmm_agent'@'20.0.0.%' identified by '123456';
    67. //在所有数据库上为 mmm_moniter(监控进程)授权
    68. grant replication client on *.* to 'mmm_monitor'@'20.0.0.%' identified by '123456';
    69. flush privileges;
    70. //在所有数据库服务器上启动 mysql-mmm-agent
    71. systemctl start mysql-mmm-agent.service
    72. systemctl enable mysql-mmm-agent.service
    73. //在 monitor 服务器上启动 mysql-mmm-monitor
    74. systemctl start mysql-mmm-monitor.service
    75. //在 monitor 服务器上测试群集
    76. #查看各节点的情况
    77. mmm_control show
    78. db1(20.0.0.81) master/ONLINE. Roles: writer(20.0.0.188)
    79. db2(20.0.0.82) master/ONLINE. Roles:
    80. db3(20.0.0.83) slave/ONLINE. Roles: reader(20.0.0.198)
    81. db4(20.0.0.84) slave/ONLINE. Roles: reader(20.0.0.199)

    1. #检测监控功能是否都完善,需要各种OK
    2. mmm_control checks all
    3. #指定绑定 VIP 的主机
    4. mmm_control move_role writer db2

    4.故障模拟 

    1. //故障测试
    2. mmm_control move_role writer db1
    3. #停止 master01 确认 VIP 是否移动到 master02 上。注意:master01 主服务器恢复服务后,不会抢占
    4. mmm_control show
    5. db1(20.0.0.81) master/HARD_OFFLINE. Roles:
    6. db2(20.0.0.82) master/ONLINE. Roles: writer(20.0.0.188)

    1. #停止一台从服务器,另一台将接管两个虚拟IP,以保证业务不停止
    2. mmm_control show
    3. db1(20.0.0.81) master/HARD_OFFLINE. Roles:
    4. db2(20.0.0.82) master/ONLINE. Roles: writer(20.0.0.188)
    5. db3(20.0.0.83) slave/HARD_OFFLINE. Roles:
    6. db4(20.0.0.84) slave/ONLINE. Roles: reader(20.0.0.198), reader(20.0.0.199)
    7. #重启服务后,虚拟IP会飘回本机

    1. //客户端测试
    2. #在 master01 服务器上为 monitor 服务器地址授权登录
    3. grant all on *.* to 'testdba'@'20.0.0.10' identified by '123456';
    4. flush privileges;
    5. #在 monitor 服务器上使用 VIP 登录
    6. yum install -y mariadb-server mariadb
    7. systemctl start mariadb.service
    8. mysql -utestdba -p -h 20.0.0.188
    9. #创建数据,测试同步情况
    10. create database db_test3;

  • 相关阅读:
    【前端验证】关于那道经典概率题,用UVM环境来仿真下是男孩的概率
    Python 获取旅游景点信息及评论并作词云、数据可视化
    Windows——安装 Microsoft 便签
    购物H5商城架构运维之路
    基于nodejs的阿里云DDNS服务,支持多网卡绑定
    Springboot在云原生中的作用
    反编译字节码分析java包装类型和引用类型及装箱与拆箱
    爆肝!阿里最新版的Spring Security源码手册,强行霸占GitHub榜首
    【完美云曦篇】新预告,云曦遭魔改被抓,石昊首秀九天劫光,反杀战王
    Biotin-NHS LC(72040-63-2)生物素接头|站点特定探针
  • 原文地址:https://blog.csdn.net/pupcarrot/article/details/134418407