一、组复制是个什么鬼?

先从 MySQL 的复制技术谈起,首先是 MySQL 的异步复制

异步复制模式下,Master上执行事务产生 binlog,slave 通过连接 master 抓取 binlog 的内容接收到本地的 relaylog 上,然后 apply 对应的事务,产生 slave 服务器上自身的 binlog(由--log-slave-update 参数决定)。流程图如下:

其次是半同步复制,流程图如下

异步复制模式下,如果 slave 全部宕机,则在 master 上的事务无法同步到 slave 上,存在一定的数据安全风险。

半同步复制解决了数据安全风险的问题,在半同步环境下要求至少有一台 slave 接收到 master 的binlog并成功写入到本地的 relaylog, master 上的事务才可以成功提交,这样对主库的事务提交速度会产生一定影响,半同步在数据安全和数据库性能两者之间做了一个中和。

在实际使用过程中,可以通过配置参数(rpl_semi_sync_master_timeout 单位是毫秒,默认为10000,即10s)设定若 slave 在多长时间没有ack返回,同步模式由半同步自动修改为异步同步模式。(mysql半同步工作原理和oracle dataguard的最大保护模式雷同)

组复制分单主模式和多主模式,mysql 的复制技术仅解决了数据同步的问题,如果 master 宕机,意味着数据库管理员需要介入,应用系统可能需要修改数据库连接地址或者重启才能实现。(这里也可以使用数据库中间件产品来避免应用系统数据库连接的问题,例如 mycat 和 atlas 等产品)。组复制在数据库层面上做到了,只要集群中大多数主机可用,则服务可用,也就是说3台服务器的集群,允许其中1台宕机。组复制的流程图如下:

组复制的特点:

● 高一致性

基于原生复制及 paxos 协议的组复制技术,并以插件的方式提供,提供一致数据安全保证;

● 高容错性

只要不是大多数节点坏掉就可以继续工作,有自动检测机制,当不同节点产生资源争用冲突时,不会出现错误,按照先到者优先原则进行处理,并且内置了自动化脑裂防护机制;

● 高扩展性

节点的新增和移除都是自动的,新节点加入后,会自动从其他节点上同步状态,直到新节点和其他节点保持一致,如果某节点被移除了,其他节点自动更新组信息,自动维护新的组信息;

● 高灵活性

有单主模式和多主模式,单主模式下,会自动选主,所有更新操作都在主上进行;

多主模式下,所有 server 都可以同时处理更新操作。

二、什么样的应用场景适合用组复制?

1、弹性的数据库复制环境

组复制可以灵活的增加和减少集群中的数据库实例

2、高可用的数据库环境

组复制允许数据库实例宕机,只要集群中大多数服务器可用,则整个数据库服务可用

3、替代传统主从复制结构的数据库环境

三、组复制的有哪些先决条件?

1、只支持innodb存储引擎

2、每张表都需要有主键

3、只支持ipv4网络环境

4、要求高网络带宽(通常是千兆内网)和低网络延迟

以下的参数在mysql数据库实例上必须要配置

1、--log-bin=bin-log     #记录mysql的binlog

2、--log-slave-update    #记录slave上进行apply relay-log时的binlog

3、--binlog-format=row  #binlog的格式为行模式

4、--gtid-mode=on      #开启gtid模式

5、--master-info-repository=TABLE   #将master-info信息记录到mysql表当中

6、--relay-log-info-repository=TABLE  #将relay-log信息记录到mysql表当中

7、--transaction-write-set-extraction=XXHASH64  #每个事务收集的wirte set和encode使用xxhash64哈希算法

8、开启多线程复制

--slave-parallel-workers=N  #N为具体的复制线程个数

--slave-preserve-commit-order=1 #slave上apply relay-log时事务顺序提交

--slave-parallel-type=LOGICAL_CLOCK  #使用多线程复制

四、组复制有哪些限制条件?

1、Replication Event Checksums

由于代码设计的原因,目前组复制还不能支持binlog的checksum,如果要使用组复制,需要配置binlog-checksum=none

2、Gap Locks

组复制校验的进程不支持间隙锁,mysql间隙锁的设计是为了解决幻读问题

3、Table Locks and Named Locks

组复制校验的进程不支持表级锁和named locks

4、SERIALIZABLE Isolation Level

组复制不支持串行事务级别

5、Concurrent DDL versus DML Operations

组复制的多主模式不支持并行的DDL和DML操作

6、Foreign Keys with Cascading Constraints

组复制的多主模式不支持带有级联约束类型的外键

7、Very Large Transactions

组复制不支持巨大的事务

参考:

https://dev.mysql.com/doc/refman/5.7/en/group-replication.html

MySQL主主复制 外键_MySQL 组复制介绍相关推荐

  1. mysql数据库的创建外键_Mysql表创建外键报错解决方案

    数据库表A: CREATE TABLE task_desc_tab ( id INT(11) PRIMARY KEY NOT NULL COMMENT '自增主键' AUTO_INCREMENT, t ...

  2. mysql是否推荐使用外键_MySQL 外键使用

    MySQL 外键使用 外键的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持): 2.外键列必须建立了索引,MySQL 4.1.2以 ...

  3. mysql中怎样插入外键_MySQL 添加外键

    MySQL 添加外键 MySQL 添加外键 DROP TABLE IF EXISTS `nation`; CREATE TABLE `nation`( `pii_Nation` smallint(2) ...

  4. mysql支持UUID做外键_Mysql中以uuid为外键插入多条数据,怎样实现同一个二级分类外键关联的数据为同一个uuid的值...

    打开我的navicat,然后找到我的teacher表,选中它,然后点击菜单栏上32313133353236313431303231363533e4b893e5b19e31333431366237的'd ...

  5. mysql数据库快捷添加外键_mysql 数据库添加外键的几种方式

    创建主表: 班级 CREATE TABLE class(cid INT PRIMARY KEY AUTO_INCREMENT, sname VARCHAR(15) NOT NULL) INSERT I ...

  6. MySQL · 捉虫动态 · 并行复制外键约束问题二

    背景 并行复制可以大大提高备库的 binlog 应用速度,内核月报也多次对并行复制特性进行介绍,感兴趣的朋友可以回顾下:5.6 并行复制实现分析.5.6 并行复制恢复实现 和 5.6并行复制事件分发机 ...

  7. mysql 开发复制协议_MySQL组复制MGR(一)– 技术概述

    (一)复制技术的发展 MySQL的复制技术主要经历了异步主从复制,半同步复制,组复制(Group Replication)3个阶段. (1)传统的异步主从复制 传统的MySQL提供了一种简单的主从复制 ...

  8. mysql删除表外键_MySQL删除所有表的外键约束、禁用外键约束

    数据库的外键虽然能保证数据数据一致性和完整性,但是也一定程度地影响了数据更新的性能.在开发中,我们使用PowerDesigner建立物理数据模型时,为了结构的清晰,增加可读性,会创建表与表之间的关联关 ...

  9. mysql给表加外键约束_MySQL为表添加外键约束

    为表添加外键约束的语法 Alter table 表名 add constraint FK_ID foreign key(外键字段名) REFERENCES 外表表名(主键字段名): 为表student ...

最新文章

  1. tomcat:Could not publish to the server. java.lang.IndexOutOfBoundsException
  2. python3 之 天天生鲜 项目 缓存cache
  3. 双十一快到了,快递却不干了?
  4. 如何判断stdin的数据类型
  5. 峰Spring4学习(5)bean之间的关系和bean的作用范围
  6. 洛谷 P2048 BZOJ 2006 [NOI2010]超级钢琴
  7. java sqlserver 图书馆管理系统_基于JAVA+SQLServer的图书馆管理系统.doc
  8. 运行JavaScript代码片段的19种工具
  9. hive 自定义UDF函数解析HTML
  10. asp.net图书馆管理系统案例
  11. 【android】项目案例(二)之京东客户端
  12. 免Flash文件上传 (Upload without Flash)
  13. UDTF's are not supported outside the SELECT clause, nor nested in expressions (state=42000,code=1008
  14. APM —全链路追踪
  15. 数据挖掘十大经典算法个人总结
  16. 看过这100个知识点,模电其实也不难
  17. 常用RL算法的主要特性
  18. Leaflet中Maker碰撞监测
  19. Android 内存泄露分析
  20. java计算器课程报告_java计算器课程设计报告

热门文章

  1. 四大对象是什么时候创建的?
  2. 集成开发环境IDE的概述
  3. SpringMVC框架的介绍
  4. Eurek Ribbon Feign常见问题及解决
  5. Spring Schedule关闭订单
  6. 希沃展台如何使用_【海安幼教微家园】玩转希沃白板 点亮精彩课堂 —长江路幼儿园开展希沃一体机操作技能培训...
  7. MySQL zip版本安装说明
  8. (转) 对svn分支合并类型和深度的理解
  9. vagrant 配置并启动
  10. 非规范SQL的sharding-jdbc实践