7.MMM

news2025/1/13 14:17:34

文章目录

  • MMM
    • 概念
    • 配置
      • mysql配置文件
      • 主主复制
      • 主从服务器配置--只需要配置一个主服务器的
      • 安装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配置文件

##所有服务器进行时间同步
ntpdate ntp.aliyun.com
##所有服务器关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
##所有的mysql服务器配置

vim /etc/my.cnf
......
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock

server-id = 1                                               #每台 Mysql 主机的 server-id 不能相同

log-error=/usr/local/mysql/data/mysql_error.log             #错误日志

general_log=ON                                              #通用查询日志

general_log_file=/usr/local/mysql/data/mysql_general.log
slow_query_log=ON                                           #慢查询日志

slow_query_log_file=mysql_slow_query.log
long_query_time=5

binlog-ignore-db=mysql,information_schema     
#不需要同步的库名

log_bin=mysql_bin    
#开启二进制日志用于主从数据复制

log_slave_updates=true      
#允许slave从master复制数据时可以写入到自己的二进制日志

sync_binlog=1          
#"双1设置",MySQL 在每写一次二进制日志时都会同步到磁盘中去  

innodb_flush_log_at_trx_commit=1     
#"双1设置",每次事务提交时MySQL都会把缓存的数据写入日志文件,并且刷到磁盘中去

auto_increment_increment=2               #自增字段一次递增多少
auto_increment_offset=1                  #自增字段的起始值

vim /etc/my.cnf
......
[mysqld]




server-id = 1                                               

log-error=/usr/local/mysql/data/mysql_error.log             

general_log=ON                                             
general_log_file=/usr/local/mysql/data/mysql_general.log

slow_query_log=ON                                           
slow_query_log_file=mysql_slow_query.log

long_query_time=5
binlog-ignore-db=mysql,information_schema     

log_bin=mysql_bin
binlog_format = mixed
log_slave_updates=1      


sync_binlog=1          
innodb_flush_log_at_trx_commit=1     


auto_increment_increment=2              
auto_increment_offset=1                  
systemctl restart mysqld

主主复制

#在两台主服务器上都执行授予从的权限,从服务器上不需要执行

grant replication slave on *.* to 'replication'@'192.168.242.%' identified by '123';


##在两台主服务器上查看,记录日志文件名称和同步点
show master status;
##主服务器1

change master to master_host='192.168.242.69',
master_user='replication',
master_password='123',
master_log_file='mysql_bin.000001',
master_log_pos=461;


start slave;

show slave status\G
##主服务器2

change master to master_host='192.168.242.66',
master_user='replication',
master_password='123',
master_log_file='mysql_bin.000001',
master_log_pos=461;


start slave;

show slave status\G

主从服务器配置–只需要配置一个主服务器的

change master to 
master_host='192.168.242.66',
master_user='replication',
master_password='123',
master_log_file='mysql_bin.000001',
master_log_pos=461;



start slave;

show slave status\G
    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes
##主服务器创建库和表,添加数据

create database test1;
use test1;
create table name (id int, name varchar(10), age int, hobby varchar(50));

insert into name values (1,'张三',16,'鸡蛋');

安装mysql-MMM

##所有服务器安装MMM
yum -y install epel-release
yum -y install mysql-mmm*
##在主服务器1上修改配置文件

cd /etc/mysql-mmm/
vim mmm_common.conf
……
<host default>
    cluster_interface       ens32
    ……
    replication_user        replication
    replication_password    123
    agent_user              mmm_agent
    agent_password          123

<host db1>
    ip      192.168.242.66
    mode    master
    peer    db2
</host>

<host db2>
    ip      192.168.242.69
    mode    master
    peer    db1
</host>

<host db3>
    ip      192.168.242.67
    mode    slave
</host>

<host db4>
    ip      192.168.242.68
    mode    slave
</host>

<role writer>
    hosts   db1, db2
    ips     192.168.242.188
    mode    exclusive           #只有一个 host 可以进行写操作模式
</role>

<role reader>
    hosts   db3, db4
    ips     192.168.242.198, 192.168.242.199
    mode    balanced            #多个 slave 主机可以进行读操作模式
</role>
//把配置文件复制到其它 4 台主机,所有主机该配置文件内容都是一样的
scp mmm_common.conf root@192.168.242.67:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.242.68:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.242.69:/etc/mysql-mmm/
scp mmm_common.conf root@192.168.242.70:/etc/mysql-mmm/
##修改所有数据库服务器的代理配置文件 mmm_agent.conf

vim /etc/mysql-mmm/mmm_agent.conf
include mmm_common.conf
this db1	

#根据不同的主机分别修改为 db1,db2,db3,db4
##在 monitor 监控服务器上修改监控配置文件 mmm_mon.conf

vim /etc/mysql-mmm/mmm_mon.conf

include mmm_common.conf
<monitor>
.....
    ping_ips        	192.168.242.66,192.168.242.67,192.168.242.68,192.168.242.69    #指定所有数据库服务器的 IP
	auto_set_online		10				#指定自动上线时间
</monitor>

<host default>
    monitor_user        mmm_monitor		#指定 mmm_monitor 的用户名
    monitor_password    123          #指定 mmm_monitor 的密码
</host>

##在所有数据库上为 mmm_agent(代理进程)授权
grant super, replication client, process on *.* to 'mmm_agent'@'192.168.242.%' identified by '123';

##在所有数据库上为 mmm_moniter(监控进程)授权
grant replication client on *.* to 'mmm_monitor'@'192.168.242.%' identified by '123';

flush privileges;
##在所有数据库服务器上启动 mysql-mmm-agent

systemctl start mysql-mmm-agent.service
systemctl enable mysql-mmm-agent.service
##在 monitor 服务器上启动 mysql-mmm-monitor

systemctl start mysql-mmm-monitor.service   

测试

##在 monitor 服务器上测试群集
#查看各节点的情况

mmm_control show


  db1(192.168.242.66) master/ONLINE. Roles: writer(192.168.242.188)
  
  db2(192.168.242.69) master/ONLINE. Roles: 
  
  db3(192.168.242.67) slave/ONLINE. Roles: reader(192.168.242.198)
  
  db4(192.168.242.68) slave/ONLINE. Roles: reader(192.168.242.199)
#检测监控功能是否都完善,需要各种OK

mmm_control checks all
#指定绑定 VIP 的主机

mmm_control move_role writer db2

故障测试

mmm_control move_role writer db1

#停止 master01 确认 VIP 是否移动到 master02 上。注意:master01 主服务器恢复服务后,不会抢占
mmm_control show

  db1(192.168.242.66) master/HARD_OFFLINE. Roles:
  db2(192.168.242.69) master/ONLINE. Roles: writer(192.168.242.188)

#停止一台从服务器,另一台将接管两个虚拟IP,以保证业务不停止
mmm_control show


 db1(192.168.242.66) master/ONLINE. Roles:
  db2(192.168.242.69) master/ONLINE. Roles: writer(192.168.242.188)
  db3(192.168.242.67) slave/HARD_OFFLINE. Roles:
  db4(192.168.242.68) slave/ONLINE. Roles: reader(192.168.242.198), reader(192.168.242.199)

客户端测试

##在 master01 服务器上为 monitor 服务器地址授权登录
grant all on *.* to 'test'@'192.168.242.70' identified by '123';

flush privileges;
#在 monitor 服务器上使用 VIP 登录
yum install -y mariadb-server mariadb
systemctl start mariadb.service

mysql -utest -p123 -h 192.168.242.188

#创建数据,测试同步情况
create database testdba;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/693698.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

git merge和git rebase的区别

本文来说下git merge和git rebase的区别 文章目录 分支合并解决冲突git rebase和git merge的区别本文小结 分支合并 git merge是用来合并两个分支的。比如&#xff1a;将 b 分支合并到当前分支。同样git rebase b&#xff0c;也是把 b 分支合并到当前分支。他们的 「原理」如下…

并发-操作系统底层工作的整体认识

冯诺依曼计算机模型 五大模块&#xff1a;输入、输出、计算器【cpu】、存储器【内存】、控制器 现在计算机硬件结构设计 CPU&#xff1a;控制、运算、数据

工业机器人运动学与Matlab正逆解算法学习笔记(用心总结一文全会)(三)

文章目录 机器人逆运动学△ 代数解求 θ 4 \theta_4 θ4​、 θ 5 \theta_5 θ5​、 θ 6 \theta_6 θ6​○ 求解 θ 4 \theta_4 θ4​○ 求解 θ 5 \theta_5 θ5​○ 求解 θ 6 \theta_6 θ6​ CSDN提示我字数太多&#xff0c;一篇发不下&#xff0c;只好拆分开x2。。。 关于…

shiro-all由1.3.2 升级到1.11.0后出现重定向次数过多的问题:ERR_TOO_MANY_REDIRECTS

最近漏洞升级, shiro-all由1.3.2 升级到1.11.0后, 导致系统登录首页打不开, 一直提示重定向次数过多: ERR_TOO_MANY_REDIRECTS: 经定位: 是shiroFilter配置中: loginUrl配置问题 以一下例子具体说明参数含义&#xff1a; 1&#xff0c;假设网站的网址是http://localhost…

基于STM32F407的智慧农业系统

文章目录 一、设备平台二、功能说明三、硬件系统设计实现与图表四、软件系统设计实现与流程图五、调试过程中出现的问题及相应解决办法六、程序设计1. 开始任务函数2. LED任务函数3. KEY任务函数4. UART任务函数5. OLED任务函数6. DHT11任务函数7. BEEP任务函数8. ADC任务函数9…

写一个简单的静态html页面demo,包含幻灯片

效果图&#xff1a; 代码如下&#xff0c;图片文件可自行更换&#xff1a; <!DOCTYPE html> <html> <head><title>公司网站</title><style>/* 样式定义 */body {font-family: Arial, sans-serif;margin: 0;padding: 0;}header {backgrou…

什么是Session

1、web中什么是会话 &#xff1f; 用户开一个浏览器&#xff0c;点击多个超链接&#xff0c;访问服务器多个web资源&#xff0c;然后关闭浏览器&#xff0c;整个过程称之为一个会话。 2、什么是Session &#xff1f; Session:在计算机中&#xff0c;尤其是在网络应用中&…

Linux学习之进程概念和ps命令

进程概念和启动关闭进程 进程就是运行中的程序 在C语言中进程只能只能从main()函数开始运行。 进程终止的方式有两种&#xff1a; 正常终止&#xff1a;从main()函数返回、调用exit()等方式 异常终止&#xff1a;调用abort、接收信号等。有可能 ps ps是“process status”的缩…

华为OD机试真题 Python 实现【光伏场地建设规划】【2023Q1 100分】

一、题目描述 祖国西北部有一片大片荒地&#xff0c;其中零星的分布着一些湖泊&#xff0c;保护区&#xff0c;矿区&#xff1b;整体上常年光照良好&#xff0c;但是也有一些地区光照不太好。某电力公司希望在这里建设多个光伏电站&#xff0c;生产清洁能源。对每平方公里的土…

React入门(B站李立超老师)

视频地址&#xff1a;https://www.bilibili.com/video/BV1bS4y1b7NV/ 课程第一部分代码&#xff1a; https://pan.baidu.com/s/16hEN7j4hLDpd7NoFiS8dHw?pwd4gxv 提取码: 4gxv 课程第二部分代码&#xff1a;https://pan.baidu.com/s/1mDkvLqYVz1QGTV1foz5mQg?pwd5zir 提取码&…

NCV2903DR2G 低偏移电压比较器

NCV2903DR2G安森美深力科是一款双独立精密电压比较器&#xff0c;能够进行单电源或分电源操作。这些设备被设计为允许在单电源操作的情况下实现共模范围到地电平。低至2.0 mV的输入偏移电压规格使该设备成为消费类汽车和工业电子中许多应用的绝佳选择。 特性&#xff1a; 1.宽…

从密码学了解如何确定物联网信息安全

一.物联网安全概述 1.信息安全的主要内容 2.密码学 编码学和分析学的关系&#xff1a;相互对立、相互依存、相互促进 3.密码学历史 1.第一阶段&#xff1a;几千年前到1949年&#xff0c;此时还没有形成一门科学&#xff0c;靠密码分析者的直觉和经验来进行 代表&#xff1a;C…

DAY35——贪心part4

1. class Solution {public boolean lemonadeChange(int[] bills) {int five 0;int ten 0;for (int i 0; i < bills.length; i) {if (bills[i] 5) {five;} else if (bills[i] 10) {five--;ten;} else if (bills[i] 20) {if (ten > 0) { //贪心 优先使用面值为10的…

8.2 PowerBI系列之DAX函数专题-进阶-实现切片器筛选之间的or逻辑

需求 两个切片器之间都被选中的情况下&#xff0c;实现符合切片器条件的并集的结果呈现&#xff0c;而非交集的结果呈现&#xff0c; 实现 or #1 var occupations values(customer[occupation]) --获取到当前切片器选中的值 var bands values(product[brand]) return s…

Node环境中调用Python脚本

今天遇到一个需要在Node服务中调用Python脚本的需求&#xff0c;这里就把这个场景单独抽离出来汇总一下方法 在node中的child_process中有execSync, exec两个方法来创建一个子进程&#xff0c;然后在子进程里执行对应的python命令&#xff0c;这两个命令可以让我们执行一个脚本…

蓝桥杯专题-试题版-【完美的代价】【芯片测试】【序列求和】【杨辉三角形】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

Jmeter分布式压测配置

目录 前置条件 环境部署并使用 前置条件 电脑A&#xff0c;电脑B&#xff0c;电脑C均安装相同版本的JMeter 和JDK。其中电脑A作为控制机&#xff0c;电脑B和电脑C作为施压机 电脑A IP&#xff1a;172.16.0.114 电脑B IP&#xff1a;172.16.0.115 电脑C IP&#xff1a;172…

PLC通讯协议【三菱】FX协议的报文格式和读写示例

通过编程口通讯协议,具体可操作的软元件有:X/Y/M/S/T/C/D。 通讯设置 必须设置为:波特率9600,偶校验,7位数据位,1停止位。否则无法通讯。 一、报文结构 注意: 通讯协议中的所有字符是用它们的十六进制ASCII码表示。如果有十进制数据,要先转化为十六进制数,再把十六进制…

数据挖掘算法常用四大类

一、常用算法有哪四大类 既然我们知道数据挖掘的算法是为了寻找数据中潜在的知识&#xff0c;那么数据挖掘的算法通常都有哪些类型呢&#xff1f;如果说按照这些算法所解决的问题来进行划分&#xff0c;大致可以分为分类问题、聚类问题、回归问题和关联分析问题。下面我们就来…

chatgpt赋能python:如何使用Python读取手机短信

如何使用Python读取手机短信 在现代社会&#xff0c;短信已成为人们生活中不可或缺的一部分。那么&#xff0c;如何利用Python读取手机短信呢&#xff1f;本文将介绍如何使用Python读取手机短信&#xff0c;并提出一些相关的建议。 什么是Python Python是一种高级的、开源的…