设为首页 收藏本站
查看: 939|回复: 0

[经验分享] MySQL 组复制介绍

[复制链接]

尚未签到

发表于 2018-9-26 13:53:36 | 显示全部楼层 |阅读模式
  一、组复制是个什么鬼?
  先从 MySQL 的复制技术谈起,首先是 MySQL 的异步复制

  异步复制模式下,Master上执行事务产生 binlog,slave 通过连接 master 抓取 binlog 的内容接收到本地的>
DSC0000.png

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

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

  半同步复制解决了数据安全风险的问题,在半同步环境下要求至少有一台 slave 接收到 master 的binlog并成功写入到本地的>  在实际使用过程中,可以通过配置参数(rpl_semi_sync_master_timeout 单位是毫秒,默认为10000,即10s)设定若 slave 在多长时间没有ack返回,同步模式由半同步自动修改为异步同步模式。(mysql半同步工作原理和oracle dataguard的最大保护模式雷同)
  组复制分单主模式和多主模式,mysql 的复制技术仅解决了数据同步的问题,如果 master 宕机,意味着数据库管理员需要介入,应用系统可能需要修改数据库连接地址或者重启才能实现。(这里也可以使用数据库中间件产品来避免应用系统数据库连接的问题,例如 mycat 和 atlas 等产品)。组复制在数据库层面上做到了,只要集群中大多数主机可用,则服务可用,也就是说3台服务器的集群,允许其中1台宕机。组复制的流程图如下:
DSC0002.png

DSC0003.png

DSC0004.png

  组复制的特点:
  ● 高一致性
  基于原生复制及 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>  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>  --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


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-602426-1-1.html 上篇帖子: RPM安装MySQL 8.0 下篇帖子: Mysql5.5部署MHA-ylw6006
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表