MySQL MMM 部署配置

jopen 6年前

MMM简介

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

MySQL本身没有提供replication failover的解决方案,通过MMM方案能实现服务器的故障转移,从而实现mysql的高可用。

MMM项目来自 Google:http://code.google.com/p/mysql-master-master

官方网站为:http://mysql-mmm.org

Mmm主要功能由下面三个脚本提供

l         mmm_mond  负责所有的监控工作的监控守护进程,决定节点的移除等等

l         mmm_agentd  运行在mysql服务器上的代理守护进程,通过简单远程服务集提供给监控节点

l         mmm_control  通过命令行管理mmm_mond进程

 

 

一、实验准备

系统: CentOS6.5 

实验主机:

function
ip
hostname
monitoring host 192.168.174.136 monitor
master1
192.168.174.134 db1
master2 192.168.174.135 db2

二、搭建MM,双MYSQL互为主从模式Replication

1.db1 db2安装mysql数据库并修改配置文件

# yum install mysql mysql-server -y  # vim /etc/my.cn

db1配置文件如下

[mysqld]  datadir=/var/lib/mysql  socket=/var/lib/mysql/mysql.sock  log-error=/var/lib/mysql/mysql.err  log = /var/lib/mysql/query_log.log  log-slow-queries = /var/lib/mysql/slow_query_log.log  user=mysql  default-character-set=utf8  init_connect='SET NAMES utf8'  # Disabling symbolic-links is recommended to prevent assorted security risks  symbolic-links=0  log-bin=mysql-bin     #开启binlog日志用于主从数据复制  server-id=1  binlog-do-db=iccstm1   #你要用于主从复制的数据库名称,多个用逗号隔开  binlog-ignore-db=mysql  #数据库名称  replicate-do-db=iccstm1  replicate-ignore-db=mysql  log-slave-updates  #此数据库宕机,备用数据库接管  slave-skip-errors=all   #跳过错误,继续执行复制  sync_binlog=1  auto_increment_increment=2  auto_increment_offset=1 #這樣A的auto_increment字段産生的數值是:1, 3, 5, 7, …等奇數ID  [client]  default-character-set=utf8  [mysqld_safe]  log-error=/var/log/mysqld.log  pid-file=/var/run/mysqld/mysqld.pid

db2配置文件如下(基本一致,server-id=2 这个不可同db1一致)

[mysqld]  datadir=/var/lib/mysql  socket=/var/lib/mysql/mysql.sock  log-error=/var/lib/mysql/mysql.err  log = /var/lib/mysql/query_log.log  log-slow-queries = /var/lib/mysql/slow_query_log.log  user=mysql  default-character-set=utf8  init_connect='SET NAMES utf8'  # Disabling symbolic-links is recommended to prevent assorted security risks  symbolic-links=0  log-bin=mysql-bin     #开启binlog日志用于主从数据复制  server-id=2  binlog-do-db=iccstm1   #你要用于主从复制的数据库名称,多个用逗号隔开  binlog-ignore-db=mysql  #数据库名称  replicate-do-db=iccstm1  replicate-ignore-db=mysql  log-slave-updates  #此数据库宕机,备用数据库接管  slave-skip-errors=all   #跳过错误,继续执行复制  sync_binlog=1  auto_increment_increment=2  auto_increment_offset=1 #這樣A的auto_increment字段産生的數值是:1, 3, 5, 7, …等奇數ID  [client]  default-character-set=utf8  [mysqld_safe]  log-error=/var/log/mysqld.log  pid-file=/var/run/mysqld/mysqld.pid

2.在MYSQL内部启用同步

取得master值

db1:

mysql> show master status\G  *************************** 1. row ***************************              File: mysql-bin.000005          Position: 526      Binlog_Do_DB: iccstm1  Binlog_Ignore_DB: mysql  1 row in set (0.00 sec)

db2:

mysql> show master status\G  *************************** 1. row ***************************              File: mysql-bin.000005          Position: 526      Binlog_Do_DB: iccstm1  Binlog_Ignore_DB: mysql  1 row in set (0.00 sec)

master_log_file对应File,master_log_pos对应Position

db1 db2互相提升访问权限

Mysql> grant all privileges on *.* to 'root'@'%' identified by '1' with grant option;

db2:

mysql> grant replication slave on *.* to 'replication'@'%' identified by '1';  mysql> flush privileges;

db1:

mysql> change master to master_host='192.168.174.135', master_user='replication', master_password='1',master_log_file='mysql-bin.000005',master_log_pos=526;  mysql> grant replication slave on *.* to 'replication'@'%' identified by '1';  mysql> flush privileges;

db2:

mysql> change master to master_host='192.168.174.134', master_user='replication', master_password='1',master_log_file='mysql-bin.000005',master_log_pos=526;

db1,db2分别查看服务器主从状态:

mysql>start slave;  mysql>show slave status\G

如果有以下两个结果

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

主从成功。

可以建立

mysql> create database iccstm1;  mysql> use iccstm1;  mysql> create table testTab(NAME set char(2));

在另外一台主机查看。

三、安装配置MySQL-MMM

1.在monitor、db1、db2上安装mmm

,并配置:mmm_common.conf、mmm_agent.conf以及mmm_mon.conf文件

首先安装epel源

适合各个操作系统的epel源列表:http://mirrors.fedoraproject.org/publiclist/EPEL/

wget http://mirrors.yun-idc.com/epel/6/x86_64/epel-release-6-8.noarch.rpm  rpm -Uvh epel-release-6-8.noarch.rpm  yum -y install mysql-mmm*

配置mmm代理和监控账号的权限

在db1和db2上分别执行:

mysql> GRANT REPLICATION CLIENT ON *.* TO 'mmm_monitor'@'192.168.174.%' IDENTIFIED BY '1';  mysql> GRANT SUPER, REPLICATION CLIENT, PROCESS ON *.* TO 'mmm_agent'@'192.168.174.%'   IDENTIFIED BY '1';  mysql> flush privileges;

配置mysql-mmm

所有的配置选项都集合在了一个叫/etc/mysql-mmm/mmm_common.conf的单独文件中,系统中所有主机的该文件内容都是一样的, 配置完后不要忘记了拷贝这个文件到所有的主机(包括监控主机)!,内容如下:

active_master_role      writer     <host default>      cluster_interface       eth0      pid_path                /var/run/mysql-mmm/mmm_agentd.pid  bin_path                /usr/libexec/mysql-mmm/  #同步的帐号(这些要和前面设置的保持一致!)      replication_user        replication        replication_password    123456    #同步的密码      agent_user              mmm_agent   #mmm-agent用户名      agent_password          1    #mmm-agent用户密码  </host>     <host db1>      ip      192.168.172.134     #db1的ip      mode    master      peer    db2  </host>     <host db2>      ip      192.168.172.135      #db2的ip      mode    master      peer    db1  </host>     <role writer>      hosts   db1, db2      ips     192.168.172.152      #设置写如的虚拟IP      mode    exclusive  </role>     <role reader>      hosts   db1, db2      ips     192.168.1.153, 192.168.1.154     #设置读取的虚拟IP      mode    balanced  </role>

在数据库主机上我们需要编辑/etc/mysql-mmm/mmm_agent.conf文件,根据其他主机的不同更改db1的值(db2就将db1更改成db2):

include mmm_common.conf  this db1

在监控主机上我们需要编辑/etc/mysql-mmm/mmm_mon.conf文件:

include mmm_common.conf     <monitor>      ip                  127.0.0.1      pid_path            /var/run/mysql-mmm/mmm_mond.pid      bin_path            /usr/libexec/mysql-mmm      status_path         /var/lib/mysql-mmm/mmm_mond.status      ping_ips            192.168.1.134,192.168.1.135  #监控服务器ip      auto_set_online     60         # 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>     <host default>      monitor_user        mmm_monitor    #mmm_monitor用户名      monitor_password    1 #mmm_monitor密码  </host>     debug 0

 启动MMM

启动代理:

(在数据库服务器上db1、db2)编辑/etc/default/mysql-mmm-agent来开启:

ENABLED=1

然后启动它:

/etc/init.d/mysql-mmm-agent start

启动监控(在监控机上):

/etc/init.d/mysql-mmm-monitor start

利用mmm_control监控mysql服务器状态:

[root@136 ~]# mmm_control show    db1(192.168.174.134) master/ONLINE. Roles: reader(192.168.174.153)    db2(192.168.174.135) master/ONLINE. Roles: reader(192.168.174.154), writer(192.168.174.152)

 测试看两个mysql服务器能否实现故障自动切换

停掉作为写的db1上的mysql,查看写的服务器会不会自动转移到db2上去

 mmm_control命令简介

[root@server3 mysql-mmm]# mmm_control help  Valid commands are:      help                              - show this message     #查看帮助信息  ping                              - ping monitor  #ping监控  show                              - show status  #查看状态信息  checks [<host>|all [<check>|all]] - show checks status  #显示检查状态,包括(ping、mysql、rep_threads、rep_backlog)  set_online <host>                 - set host <host> online  #设置某host为online状态  set_offline <host>                - set host <host> offline  #设置某host为offline状态  mode                              - print current mode.  #打印当前的模式,是ACTIVE、MANUAL、PASSIVE?  #默认ACTIVE模式  set_active                        - switch into active mode.  #更改为active模式  set_manual                        - switch into manual mode.  #更改为manual模式  set_passive                       - switch into passive mode.  #更改为passive模式      move_role [--force] <role> <host> - move exclusive role <role> to host <host>         #更改host的模式,比如更改处于slave的mysql数据库角色为write       (Only use --force if you know what you are doing!)  set_ip <ip> <host>                - set role with ip <ip> to host <host>  #为host设置ip,只有passive模式的时候才允许更改!