CENTOS6.6下mysql MMM架构搭建

本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn

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

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

实现原理

两台master互为主从,一台为只读,做为备份,应急时可做为写master.其中mmm_mond进程定时心跳检测,失败则将write ip 浮动到另外一台master。

MySQL-MMM优缺点

  1. 优点:高可用性,扩展性好,出现故障自动切换,对于主主同步,在同一时间只提供一台数据库写操作。
  2. 缺点:Monitor节点是单点,可以结合Keepalived实现高可用
  3. 由于MMM无法完全的保证数据一致性,所以MMM适用于对数据的一致性要求不是很高,但是又想最大程度的保证业务可用性的场景。对于那些对数据的一致性要求很高的业务,非常不建议采用MMM这种高可用架构。

安装mysql软件

在每台服务器上安装mysql软件,安装参照《linux 6 源码安装mysql5.6》 在每台服务器上关闭selinux,关闭防火墙 在配置文件my.cnf里增加如下内容:

[mysqld]
datadir=/usr/local/mysql/data
socket=/var/lib/mysql/mysql.sock
user=mysql

#下面为新添加的内容
default-storage-engine = innodb

replicate-ignore-db = mysql
binlog-ignore-db= mysql

server-id   = 1
log-bin = /usr/local/mysql/logs/mysql-bin.log
log_bin_index   = /usr/local/mysql/logs/mysql-bin.log.index
relay_log   = /usr/local/mysql/logs/mysql-bin.relay
relay_log_index = /usr/local/mysql/logs/mysql-bin.relay.index
expire_logs_days= 10
max_binlog_size = 100M
log_slave_updates
sync-binlog = 1 

在/etc/hosts里配上所有主机信息

192.168.10.131 db1
192.168.10.132 db2
192.168.10.133 db3
192.168.10.134 db4
192.168.10.135 db5

配置主主复制

即两个主master(db1、db2)互为主从,与主从类似,只是需要逆向配置一下。
a、先查看db1 db2 binlog日志和pos值
db1

db2

b、在db1执行:

mysql> GRANT REPLICATION SLAVE ON *.* TO ‘replication‘@‘192.168.10.%‘ IDENTIFIED BY ‘replication‘;
mysql> flush privileges;
mysql> change master to master_host=‘192.168.10.132‘, master_user=‘replication‘,master_password=‘replication‘, master_log_file=‘mysql-bin.000003‘,master_log_pos=120;
mysql> start slave; #启动同步  

c、在db2执行:

mysql> GRANT REPLICATION SLAVE ON *.* TO ‘replication‘@‘192.168.10.%‘ IDENTIFIED BY ‘replication‘;
mysql> flush privileges;
mysql> change master to master_host=‘192.168.10.131‘, master_user=‘replication‘,master_password=‘replication‘, master_log_file=‘mysql-bin.000001‘,master_log_pos=120;
mysql> start slave; #启动同步

db3、db4作为db1的从库slave

在db3、db4上执行

mysql> change master to master_host=‘192.168.10.131‘, master_user=‘replication‘,master_password=‘replication‘, master_log_file=‘mysql-bin.000001‘,master_log_pos=120;
mysql> start slave; #启动同步

MYSQL-MMM的安装

(1)epel源安装
CentOS 默认没有 mysql-mmm 软件包,官方推荐使用 epel 的网络源,五台都安装epel:

wget http://mirrors.hustunique.com/epel/6/x86_64/epel-release-6-8.noarch.rpm
wget http://mirrors.hustunique.com/epel/RPM-GPG-KEY-EPEL-6
rpm --import RPM-GPG-KEY-EPEL-6
rpm -ivh epel-release-6-8.noarch.rpm 

(2)monitor节点安装db5
在db5上执行

yum -y install mysql-mmm-monitor  

(3)四台db节点上安装agent
在db1 db2 db3 db4上执行

yum -y install mysql-mmm-agent

(4)四台db节点上授权monitor访问
在db1 db2 db3 db4执行

mysql -uroot -p
mysql> GRANT REPLICATION CLIENT ON *.* TO ‘mmm_monitor‘@‘192.168.10.%‘ IDENTIFIED BY ‘monitor‘;
mysql> GRANT SUPER,REPLICATION CLIENT, PROCESS ON *.* TO ‘mmm_agent‘@‘192.168.10.%‘ IDENTIFIED BY‘agent‘;  

(5)在db1上修改mmm_common.conf文件(5台相同)

vi /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_userreplication
replication_passwordreplication
agent_user  mmm_agent
agent_password  agent
</host>

<host db1>
ip  192.168.10.131
modemaster
peerdb2
</host>

<host db2>
ip  192.168.10.132
modemaster
peerdb1
</host>

<host db3>
ip  192.168.10.133
modeslave
</host>

<host db4>
ip  192.168.10.134
modeslave
</host>

<role writer>
hosts   db1, db2
ips 192.168.10.128
modeexclusive #只有一个虚拟IP可以写
</role>

<role reader>
hosts   db3, db4
ips 192.168.10.129, 192.168.10.130
modebalanced #多个虚拟ip可以读
</role>

传到其它4个节点

scp /etc/mysql-mmm/mmm_common.conf [email protected]192.168.10.132:/etc/mysql-mmm/
scp /etc/mysql-mmm/mmm_common.conf [email protected]192.168.10.133:/etc/mysql-mmm/
scp /etc/mysql-mmm/mmm_common.conf [email protected]192.168.10.134:/etc/mysql-mmm/
scp /etc/mysql-mmm/mmm_common.conf [email protected]192.168.10.135:/etc/mysql-mmm/

若无scp命令,安装一下包

yum install openssh-clients

(6)修改四台db代理端 mmm_agent.conf 文件
在db1 db2 db3 db4上修改

vi /etc/mysql-mmm/mmm_agent.conf
include mmm_common.conf
this db1   #分别修改为本机的主机名,即db1、db2、db3和db4

(7)修改管理端的mmm_mon.conf文件
在db5上执行

vi /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_ips192.168.10.131,192.168.10.132,192.168.10.133,192.168.10.133,192.168.10.134 #真实数据库IP,来检测网络是否正常
auto_set_online 10  #恢复后自动设置在线的时间
</monitor>
<host default>
monitor_usermmm_monitor
monitor_passwordmonitor
</host>
debug 0

启动MYSQL-MMM

(1)db代理端启动db1 db2 db3 db4

[[email protected] ~]# /etc/init.d/mysql-mmm-agent start
[[email protected] ~]# chkconfig mysql-mmm-agent on

(2)monitor管理端启动 db5

[[email protected] ~]# /etc/init.d/mysql-mmm-monitor start
[[email protected] ~]# chkconfig mysql-mmm-monitor on

测试集群

(1)查看集群状态db5
mmm_control show

(2)故障转移
模拟停掉db1数据库后

看它的状态变了

时间: 2024-10-16 22:37:10

CENTOS6.6下mysql MMM架构搭建的相关文章

CENTOS6.6 下mysql MHA架构搭建

本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn 摘要: 本篇是自己搭建的一篇mysql MHA文章 前面的安装步骤基本不变,后面的比如keepalived的配置文件有几种方法 其实想完成keepalived+lvs+atlas(mycat)+mha+mysql主从复制 这样的架构,只是MYCAT单独文章了 每个节点都关闭防火墙,SELINUX. 1.安装epel yum源 wget http://mirrors.

CentOS6.4下Mysql数据库的安装与配置,导入数据库,授权远程ip

卸载掉原有mysql 因为mysql数据库在Linux上实在是太流行了,所以目前下载的主流Linux系统版本基本上都集成了mysql数据库在里面,我们可以通过如下命令来查看我们的操作系统上是否已经安装了mysql数据库 [[email protected] ~]# rpm -qa | grep mysql // 这个命令就会查看该操作系统上是否已经安装了mysql数据库 有的话,我们就通过 rpm -e 命令 或者 rpm -e --nodeps 命令来卸载掉 [[email protected

Vmware Centos6.2下mysql的安装配置

1.vmware10安装centos6 http://jingyan.baidu.com/article/afd8f4de6c25c534e286e9d9.html 2.Vmware Centos6.2下mysql的安装配置 http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 3.navicat无法连接mysql解决方案 http://www.cnblogs.com/zhuawang/p/3918616.

ubuntu 下 mysql数据库的搭建 及 数据迁移

1.mysql的安装 我是使用apt-get直接安装的 :sudo apt-get install mysql-server sudo apt-get install mysql-client 2.配置mysql管理员密码 sudo mysqladmin -u root 当前密码 新密码 安装的时候貌似也没遇到什么障碍 3.查看mysql的状态 sudo netstat -tap | grep mysql 4.启动/停止/重启mysql sudo  /etc/init.d/mysql start

Linux学习之CentOS(十三)--CentOS6.4下Mysql数据库的安装与配置

原文:http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 如果要在Linux上做j2ee开发,首先得搭建好j2ee的开发环境,包括了jdk.tomcat.eclipse的安装(这个在之前的一篇随笔中已经有详细讲解了Linux学习之CentOS(七)--CentOS下j2ee环境搭建),如果要开发web项目,我们当然可以安装一个myeclipse到Linux系统上去,这个安装方法和安装eclipse完全相同

mysql mmm架构看不到vip地址

自己搭建好mysql mmm(Master-Master Replication Manager)高可用架构后看不到vip地址,经过在网上找了大量的文章和自己平时的观察终于发现找出vip地址的方法了,现在分享给大家. 1.在mmm监控服务器查看各节点的状态 [[email protected] bin]# mmm_control  show  db2(192.168.56.105) master/ONLINE. Roles: writer(192.168.56.100)  node1(192.1

一次mysql MHA架构搭建过程

[环境介绍] 系统环境:Red Hat Enterprise Linux 7 + 5.7.18 + MHA version 0.57 系统 IP 主机名 备注 版本 xx系统 192.168.142.111 mysqlmha1 主库 5.7.18 -log MySQL Community Server (GPL) 192.168.142.112 mysqlmha2 备库(预主库) 192.168.142.113 mysqlmha3 备库/MHA MGM 192.168.142.111 mysql

CentOS6.4下Mysql数据库的安装与配置

转自:http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 如果要在Linux上做j2ee开发,首先得搭建好j2ee的开发环境,包括了jdk.tomcat.eclipse的安装(这个在之前的一篇随笔中已经有详细讲解了Linux学习之CentOS(七)--CentOS下j2ee环境搭建),如果要开发web项目,我们当然可以安装一个myeclipse到Linux系统上去,这个安装方法和安装eclipse完全相同

170116、centos6.4下nginx和ftp搭建图片服务器

一.需要的组件 图片服务器两个服务: Nginx(图片访问): 1.http服务:可以使用nginx做静态资源服务器.也可以使用apache.推荐使用nginx,效率更高. 2.反向代理 实现 负载均衡 ftp服务(图片上传): 使用Linux做服务器,在linux中有个ftp组件vsftpd. 二.Nginx服务器搭建 1.安装Nginx 要求安装vmware虚拟机. Linux:CentOS6.4(32) Nginx:1.8.0 Vsftpd:需要在线安装. 虚拟机以及Linux安装很简单此