Microsoft Azure部署MYSQL-MMM(1)安装MYSQL

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

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进程

在两个节点的master-master环境下,MMM使用5IP。每个单独的节点使用一个固定IP,这个固定IP永远不会变化。

2reader IPs(read-only)和一个writer IP(updates),后面三个IP(2reader IP和一个Writer IP)在两个节点之间迁移,如何迁移取决于节点的可用性。


正常情况下(没有复制失败,没有复制延迟等)活动的master有两个虚拟ip(readerwriter),备用的master有一个虚拟ip(reader),如果活动的master失败了,那么所有的readerwriter虚拟IP都会被分配给备用的master


具体的配置信息如下所示:

角色                    ip地址          主机名字                server-id

monitoring           10.0.0.6         monitor                      -

master1              10.0.0.4         db1                      1

master2              10.0.0.5         db2                      2

slave1               10.0.0.7         db3                      3


业务中的服务ip信息如下所示:

ip地址                  角色                    描述

10.0.0.80           write           应用程序连接该ip对主库进行写请求

10.0.0.90            read            应用程序连接该ip进行读请求

10.0.0.100            read            应用程序连接该ip进行读请求


部署架构如下图:



MySQL-MMM优缺点

优点:高可用性,扩展性好,出现故障自动切换,对于主主同步,在同一时间只提供一台数据库写操作,保证的数据的一致性。

缺点:Monitor节点是单点,可以结合Keepalived实现高可用。


具体的部署步骤如下:

1)主机配置

Azure中创建一个虚拟网络,然后在库中创建虚拟机,选择基于CENTOS Openlogic 6.5

PS:由于MMM的监控机制需要检查PING,请确保所有虚拟机在一个VNET下。



同时完成四台虚拟机的创建,分别是master1、master2、slave、monitor,如下图:


使用那个Xshell连接到VM


首先获取root权限并修改root密码,如下操作

Sudo su -

输入密码

Passwd root


在每一台服务器上用yum命令安装MYSQL服务

# yum install mysql-server


安装完成后重启MYSQL服务

# service mysqld restart


连接到mysql,修改mysql root密码,如下操作:

# mysql -uroot

use mysql

update user set password=password('p@ssw0rd') where user='root';

flush privileges;


select user,host,password from mysql.user



















本文转自李珣51CTO博客,原文链接:http://blog.51cto.com/lixun/1629177 ,如需转载请自行联系原作者


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
关系型数据库 MySQL 数据库
龙蜥操作系统上安装MySQL:步骤详解与常见问题解决
龙蜥操作系统上安装MySQL:步骤详解与常见问题解决
|
2天前
|
关系型数据库 MySQL Linux
在Centos7中:通过Docker安装MySQL5.7(保姆级)
在Centos7中:通过Docker安装MySQL5.7(保姆级)
|
2天前
|
编解码 安全 关系型数据库
祝福CSDN的小伙伴2024年快乐!Windows7安装MySQL
祝福CSDN的小伙伴2024年快乐!Windows7安装MySQL
|
4天前
|
关系型数据库 MySQL Linux
Linux CentOs7 安装Mysql(5.7和8.0版本)密码修改 超详细教程
Linux CentOs7 安装Mysql(5.7和8.0版本)密码修改 超详细教程
|
5天前
|
安全 关系型数据库 MySQL
MySQL安装教程
MySQL安装教程
28 0
|
5天前
|
SQL 关系型数据库 MySQL
【简单无脑】自动化脚本一键安装虚拟机下的MySQL服务
该文章提供了在虚拟机上安装MySQL服务的简化方法,特别是针对新手。作者提供了一个自动化脚本`install_mysql.sh`,使得安装过程更简单。用户需要下载`install.rpm`资源,将其放在指定目录下,然后创建并编辑脚本文件,将提供的代码粘贴进去,通过`chmod u+x`授权,最后运行脚本`./install_mysql.sh [rpm文件路径]`来安装MySQL。文章还附有相关图片说明。
15 1
【简单无脑】自动化脚本一键安装虚拟机下的MySQL服务
|
5天前
|
SQL 缓存 关系型数据库
MySQL常见问题解决和自动化安装脚本
这篇内容包含了两个主要部分:解决MySQL登录问题和处理GPG密钥问题。当MySQL密码正确但无法登录时,可以通过执行SQL命令`ALTER USER`和`flush privileges`来修改和重置密码。对于MySQL安装时的GPG密钥错误,首先需要强制删除旧的MySQL仓库包,导入新的GPG公钥,然后安装MySQL服务器。如果遇到GPG检查错误,可以使用`--nogpgcheck`参数忽略检查来安装。最后,提供了一个自动化安装MySQL的脚本,用于检查旧版本、卸载残留、安装MySQL8并启动服务。
21 1
MySQL常见问题解决和自动化安装脚本
|
2天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
11 0
|
9天前
|
关系型数据库 MySQL Linux
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
|
9天前
|
SQL 关系型数据库 MySQL
【MySQL-5】DDL的数据库操作:查询&创建&删除&使用(可cv代码+演示图)
【MySQL-5】DDL的数据库操作:查询&创建&删除&使用(可cv代码+演示图)