如何将MySQL GR 设置为多主模式

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

在MySQL 5.7.17版本中发布的MySQL Group Replication(后文简称为MGR)被很多人称为MySQL复制方案的正规军,可以一举取代现在的MySQL Replication,Semisynchronous replication,甚至是可以取代之前最成功的MySQL集群方案Galera。


MGR有两种模式,一种是Single-Primary,一种是Multi-Primary,单主或者多主。


在前一种模式Single-Primary中,无论集群中有多少个节点,只有一个节点允许写入,其它节点都是只读的,这个允许写入的节点被称为主节点,只有当这个主节点出现问题从集群中被踢出,才会在剩余的节点中选举出另外一个节点成为新的主节点,并且将该节点置为可写模式。这个过程可以通过log清晰地看到。

640?wx_fmt=png&wxfrom=5&wx_lazy=1


在5.7.17的官方文档中有详细地描述如何设置Single-Primary MGR的方法。

Deploying Group Replication in Single-Primary Mode(https://dev.mysql.com/doc/refman/5.7/en/group-replication-deploying-in-single-primary-mode.html)


而在后一种模式Multi-Primary中,所有的节点都是主节点,都可以同时被读写,看上去这似乎更好,但是因为多主的复杂性,在功能上如果设置了多主模式,则会有一些使用的限制,比如不支持Foreign Keys with Cascading Constraints。


在多主模式下,集群中的节点退出集群,也不再会出现重新选举的动作,因为本来所有的节点都是Primary节点。


但是不确认是什么原因,在官方文档中没有单独的章节来描述如何设置集群为Multi-Primary模式。只是在最后语焉不详地提及了一句:Multi-primary mode groups (members all configured with group_replication_single_primary_mode=OFF) 让读者可以知道跟group_replication_single_primary_mode参数有关。


以下为设置Multi-Primary MGR的方法。假设集群之前已经处于Single-Primary模式。


group_replication_single_primary_mode=ON,表示启动了Single-Primary模式,那么修改为OFF就意味着要启动Multi-Primary模式。

640?wx_fmt=png&wxfrom=5&wx_lazy=1


如果MGR已经启动,则无法动态修改该参数

640?wx_fmt=png&wxfrom=5&wx_lazy=1


首先停止复制

root@lh> stop GROUP_REPLICATION;

Query OK, 0 rows affected (8.67 sec) 


设置单主模式参数为off

root@lh > set global group_replication_single_primary_mode=off;

Query OK, 0 rows affected (0.00 sec)


该参数设置为ON,则禁用了在多主模式下一些可能产生未知数据冲突的操作

(root@lh) > set global group_replication_enforce_update_everywhere_checks=ON;

Query OK, 0 rows affected (0.00 sec) 


设置为第一个准备启动MGR(bootstrap)的节点

root@lh> SET GLOBAL group_replication_bootstrap_group=ON;

Query OK, 0 rows affected (0.00 sec) 


启动复制 

root@lh> START GROUP_REPLICATION;

Query OK, 0 rows affected (1.29 sec) 


 为了防止后续由于意外再启动另外一个复制组,关闭bootstrap参数

root@lh]> SET GLOBAL group_replication_bootstrap_group=OFF;

Query OK, 0 rows affected (0.00 sec) 


此时可以从视图中看到整个集群只有一个节点是ONLINE

640?wx_fmt=png&wxfrom=5&wx_lazy=1


可以加入第二个节点了。

同样设置单主模式参数为off

root@lh> set global group_replication_single_primary_mode=off;

Query OK, 0 rows affected (0.00 sec) 


设置update检查参数为on

root@lh> set global group_replication_enforce_update_everywhere_checks=ON;

Query OK, 0 rows affected (0.00 sec) 


启动复制

root@lh> start group_replication;

Query OK, 0 rows affected (5.42 sec) 


此时检查视图,可以发现集群中已经存在两个节点

640?wx_fmt=png&wxfrom=5&wx_lazy=1


group_replication_primary_member值为空,表示启动的是Multi-Primary Mode,否则该参数显示的是单主模式中的Primary节点。

640?wx_fmt=png&wxfrom=5&wx_lazy=1


同样的方法可以加入第三个节点,在当前版本中MGR最多支持一个集群中拥有9个节点。


如果需要在MySQL重启之后这些参数仍然生效,那么需要将这些参数加入到my.cnf文件中,一个典型的配置了MGR的my.cnf如下所示

640?wx_fmt=png&wxfrom=5&wx_lazy=1



本文出自数据和云公众号,原文链接


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
SQL 关系型数据库 MySQL
mysql用户权限设置
mysql用户权限设置
|
30天前
|
网络协议 关系型数据库 MySQL
mysql8.0远程连接权限设置
mysql8.0远程连接权限设置
55 0
|
2月前
|
关系型数据库 MySQL 数据库
MySQL时间字段设置自动更新
MySQL时间字段设置自动更新
27 0
|
3月前
|
SQL 关系型数据库 MySQL
mysql使用default给列设置默认值的问题
mysql使用default给列设置默认值的问题
34 0
|
3月前
|
关系型数据库 MySQL 数据库
百度搜索:蓝易云【【Docker】Docker部署Mysql并设置数据持久化教程】
通过以上步骤,您已经成功地在Docker中部署了MySQL,并设置了数据持久化,确保数据在容器重新启动或迁移时得以保留。
50 0
|
3月前
|
关系型数据库 MySQL API
|
2月前
|
关系型数据库 MySQL Docker
MySQL 5.7 timestamp类型设置default value为'0000-00-00 00:00:00'报错的解决方法
MySQL 5.7 timestamp类型设置default value为'0000-00-00 00:00:00'报错的解决方法
|
1月前
|
安全 关系型数据库 应用服务中间件
连接rds设置网络权限
连接阿里云RDS需关注:1) 设置白名单,允许特定IP访问;2) 选择合适网络类型,如VPC或经典网络;3) 确保VPC内路由与安全组规则正确;4) 同VPC内可使用内网地址连接;5) 可启用SSL/TLS加密增强安全性。记得遵循最小权限原则,确保数据库安全。不同服务商操作可能有差异,但基本流程相似。
24 9
|
1月前
|
SQL 关系型数据库 MySQL
923.【mysql】 only full group by 模式
923.【mysql】 only full group by 模式
20 1
|
3月前
|
监控 关系型数据库 MySQL
MySQL全面解析:安装与设置详细指南
【1月更文挑战第1天】,MySQL是一款开源的关系型数据库管理系统,被广泛应用于Web应用程序的开发中。本文将深入探讨MySQL的概念、特性,以及详细介绍MySQL的安装和设置过程,帮助你快速搭建一个强大的数据库环境。
228 0
MySQL全面解析:安装与设置详细指南