基于MySQL组复制(MGR)实现主从搭建流程


前言

环境 : CentOS 7.7 丶Docker 19.03.4丶MySQL 8.0.16

本教程仅用于对MySQL的组复制搭建教程示例,其余搭建方式不在本文讨论范围内,文中提及相关知识参考自MySQL官方文档 :MySQL组复制

个人建议使用MySQL版本为8.0.16

前期准备
  • 服务器准备

    文中采用两台CentOS 7.7进行测试

    节点 IP
    master-one 192.168.107.185
    master-two 192.168.107.109
  • hosts映射
    ## 添加hosts 映射,每个MySQL节点都需要修改hosts文件
    vim /etc/hosts
    192.168.107.185   master-one  master-one
    192.168.107.109   master-two  msater-two
    
  • 多节点部署

    在两个服务器主机分别部署MySQL,本文仅用于说明主从搭建示例,对MySQL部署在此不过多阐述,详情请参考 :

    Docker 安装 MySQL

单主模式
  • 配置修改
    [mysqld]
    # 修改三个节点 my.cnf 配置文件
    
    # 修改默认密码验证插件
    default_authentication_plugin=mysql_native_password
    
    # 禁用其他引擎,对于组复制,数据必须存储在InnoDB事务存储引擎中
    disabled_storage_engines="MyISAM,BLACKHOLE,FEDERATED,ARCHIVE,MEMORY"
    
    # 配置复制  
    server_id=38                     # 组内唯一ID,不可重复,一般配置为IP的后几位        
    gtid_mode=ON                     # 开启gtid模式,通过全局事务标识记录DDL及DML
    enforce_gtid_consistency=ON            # 
    binlog_checksum=NONE              # 禁用二进制日志时间校验和  
    
    # 若MySQL版本在 8.0.3之前需增加如下配置
    # log_bin=binlog                  # 开启二进制日志 
    # log_slave_updates=ON                # 开启存储从主库接收来的二进制日志  
    # binlog_format=ROW                   # 设置二进制日志格式为row  
    # master_info_repository=TABLE         # 复制元数据存入系统表  
    # relay_log_info_repository=TABLE     # 复制元数据存入系统表 
    
    # 组复制配置
    
    # 若MySQL版本在8.0.2 之前需要加入此项,对于每个事务,它必须收集写集,并使用XXHASH64哈希算法将其编码为哈希
    # transaction_write_set_extraction=XXHASH64
    # 将组复制插件添加到服务器在启动时加载的插件列表中
    plugin_load_add='group_replication.so'
    # 告诉插件将其加入或创建的组命名为
    group_replication_group_name="aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"
    # 设置为on时,会在服务器启动时自动启动组复制
    group_replication_start_on_boot=off
    # 设置成员用于与组中其他成员进行内部通信的网络地址和端口
    group_replication_local_address= "master-one:33061"
    # 设置组成员的主机名和端口
    group_replication_group_seeds= "master-one:33061,master-two:33061"
    # 是否为Group Replication的引导节点,集群中第一个节点需要设置为ON来启动Group Replication,如果不在配置文件中配置可在后面动态配置
    group_replication_bootstrap_group=off
    # 一般配置为本机地址,如果不做映射那么要配置这个  
    # report_host = 172.16.146.38  
    # report_port=33061  
    

    多节点配置,若无特殊需求,仅根据实际情况修改如下三项即可

     # 保证每个节点唯一,不可重复
     server_id = 203                              
     # 根据节点具体IP修改
     loose-group_replication_local_address = 'master-one:33061'   
     # 若修改了hosts文件进行IP映射配置,则不需修改此项
     # report_host = 172.16.146.38                 
    
  • 重启容器
    # 重启MySQL
    docker restart [容器ID]
    
  • 创建用户(每个节点执行)
    #进入MySQL容器
    docker exec -it [容器ID] /bin/bash
    # 连接MySQL
    mysql -uroot -ppassword
    # 关闭二进制日志文件记录
    SET SQL_LOG_BIN=0;
    # 创建用户
    CREATE USER slave@'%' IDENTIFIED BY 'password';
    # mysql 8.0 需修改密码使用插件
    ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY 'password'; 
    # 授权用于复制
    GRANT REPLICATION SLAVE ON *.* TO slave@'%';
    GRANT BACKUP_ADMIN ON *.* TO slave@'%';
    # 刷新权限
    FLUSH PRIVILEGES;
    # 开启二进制日志文件记录
    SET SQL_LOG_BIN=1;
    # 设置使用组复制的用户,配置状态转移
    CHANGE MASTER TO MASTER_USER='slave', MASTER_PASSWORD='password' FOR CHANNEL 'group_replication_recovery';
    
  • 开启组复制
    ------------------配置主节点------------------
    
    # 查看已安装插件
    SHOW PLUGINS;
    # 若未安装group_replication插件,手动安装
    INSTALL PLUGIN group_replication SONAME 'group_replication.so';
    # 开启插件自动引用组功能
    SET GLOBAL group_replication_bootstrap_group=ON;
    # 开启组复制
    START GROUP_REPLICATION;
    # 关闭插件自动引用组功能
    SET GLOBAL group_replication_bootstrap_group=OFF;
    
    ------------------配置从节点------------------
    # 开启组复制
    START GROUP_REPLICATION;
    
    -------------------状态查看-------------------
    # 查看主节点
    SELECT MEMBER_HOST, MEMBER_ROLE FROM performance_schema.replication_group_members;
    # 查看组状态
    SELECT * FROM performance_schema.replication_group_members;
    # 查看组统计信息
    SELECT * FROM performance_schema.replication_group_member_stats\G;
    
    
多主模式(MySQL 8.0.16之后 )
  • 配置多主模式
    # 停止组复制(所有节点执行):
    mysql> STOP GROUP_REPLICATION;
    mysql> RESET MASTER;
    mysql> SET GLOBAL group_replication_single_primary_mode=OFF;
    mysql> SET GLOBAL group_replication_enforce_update_everywhere_checks=ON;
    
    # 随便选择某个节点执行
    mysql> SET GLOBAL group_replication_bootstrap_group=ON; 
    mysql> START GROUP_REPLICATION; 
    mysql> SET GLOBAL group_replication_bootstrap_group=OFF;
    
    # 其他节点执行
    mysql> START GROUP_REPLICATION; 
    
    # 查看组信息,所有节点的 MEMBER_ROLE 都为 PRIMARY
    SELECT * FROM performance_schema.replication_group_members;
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351