【MySQL】主从复制(重点:主从复制原理)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 本文重点介绍MySQL的主从复制概述,作用,原理,同步数据一致性问题。

【大家好,我是爱干饭的猿,本文重点介绍MySQL的主从复制概述,作用,原理,同步数据一致性问题。

后续会继续分享Redis和其他重要知识点总结,如果喜欢这篇文章,点个赞👍,关注一下吧】

上一篇文章:《【MySQL】MVCC多版本并发控制(重点:MVCC实现原理之ReadView)》


目录

🥞1. 主从复制概述

1.1 如何提升数据库并发能力

1.2 主从复制的作用

🥞2. 主从复制的原理

2.1 原理剖析

2.2 复制的基本原则

🥞3. 同步数据一致性问题

3.1 理解主从延迟问题

3.2 主从延迟问题原因

3.3 如何减少主从延迟

3.4 如何解决一致性问题


SQL语句中 DDL 、DML 、DQL 、DCL:

    • DDL:DDL(Data Definition Language)语句: 数据定义语言,主要是进行定义/改变表的结构、数据类型、表之间的链接等操作。常用的语句关键字有 CREATE、DROP、ALTER 等。
    • DML:DML(Data Manipulation Language)语句: 数据操纵语言,主要是对数据进行增加、删除、修改操作。常用的语句关键字有 INSERT、UPDATE、DELETE 等。
    • DQL:DQL(Data Query Language)语句:数据查询语言,主要是对数据进行查询操作。常用关键字有 SELECT、FROM、WHERE 等。
    • DCL:DCL(Data Control Language)语句: 数据控制语言,主要是用来设置/更改数据库用户权限。常用关键字有 GRANT、REVOKE 等。

    🥞1.主从复制概述

    1.1如何提升数据库并发能力

    image.gif编辑

    一般应用对数据库而言都是“读多写少”,也就说对数据库读取数据的压力比较大,有一个思路就是采用数据库集群的方案,做主从架构、进行读写分离,这样同样可以提升数据库的并发处理能力。但并不是所有的应用都需要对数据库进行主从架构的设置,毕竟设置架构本身是有成本的。

    如果我们的目的在于提升数据库高并发访问的效率,那么首先考虑的是如何优化SQL和索引,这种方式简单有效;其次才是采用缓存的策略,比如使用 Redis将热点数据保存在内存数据库中,提升读取的效率;最后才是对数据库采用主从架构,进行读写分离。

    1.2主从复制的作用

    第1个作用:读写分离。

    image.gif编辑

    第2个作用:数据备份。

    第3个作用:具有高可用性。

    🥞2.主从复制的原理

    2.1原理剖析

    三个线程

    实际上主从同步的原理就是基于 binlog 进行数据同步的。在主从复制过程中,会基于3 个线程来操作,一个主库线程,两个从库线程。

    image.gif编辑

    二进制日志转储线程(Binlog dump thread)是一个主库线程。当从库线程连接的时候, 主库可以将二进制日志发送给从库,当主库读取事件(Event)的时候,会在 Binlog 上加锁,读取完成之后,再将锁释放掉。

    从库 I/O 线程会连接到主库,向主库发送请求更新 Binlog。这时从库的 I/O 线程就可以读取到主库的二进制日志转储线程发送的 Binlog 更新部分,并且拷贝到本地的中继日志 (Relay log)。

    从库 SQL 线程会读取从库中的中继日志,并且执行日志中的事件,将从库中的数据与主库保持同步。

    image.gif编辑

    复制三步骤(面试重点)

    步骤1:Master将写操作记录到二进制日志(binlog)。

    步骤2:SlaveMaster的binary log events拷贝到它的中继日志(relay log);

    步骤3:Slave重做中继日志中的事件,将改变应用到自己的数据库中。 MySQL复制是异步的且串行化的,而且重启后从接入点开始复制。

    复制的问题

    复制的最大问题:延时

    2.2复制的基本原则

      • 每个Slave只有一个Master
      • 每个Slave只能有一个唯一的服务器ID
      • 每个Master可以有多个Slave

      🥞3.同步数据一致性问题

      主从同步的要求:

        • 读库和写库的数据一致(最终一致);
        • 写数据必须写到写库;
        • 读数据必须到读库(不一定);

        3.1理解主从延迟问题

        进行主从同步的内容是二进制日志,它是一个文件,在进行网络传输的过程中就一定会存在主从延迟(比如 500ms),这样就可能造成用户在从库上读取的数据不是最新的数据,也就是主从同步中的数据不一致性问题。

        3.2主从延迟问题原因

        在网络正常的时候,日志从主库传给从库所需的时间是很短的,即T2-T1的值是非常小的。即,网络正常情况下,主备延迟的主要来源是备库接收完binlog和执行完这个事务之间的时间差。

        主备延迟最直接的表现是,从库消费中继日志(relay log)的速度,比主库生产binlog的速度要慢。造成原因:

        1、从库的机器性能比主库要差

        2、从库的压力大

        3、大事务的执行

        3.3如何减少主从延迟

        若想要减少主从延迟的时间,可以采取下面的办法:

          1. 降低多线程大事务并发的概率,优化业务逻辑
          2. 优化SQL,避免慢SQL,减少批量操作,建议写脚本以update-sleep这样的形式完成。
          3. 提高从库机器的配置,减少主库写binlog和从库读binlog的效率差。
          4. 尽量采用短的链路,也就是主库和从库服务器的距离尽量要短,提升端口带宽,减少binlog传输的网络延时。
          5. 实时性要求的业务读强制走主库,从库只做灾备,备份。

          3.4如何解决一致性问题

          读写分离情况下,解决主从同步中数据不一致的问题, 就是解决主从之间 数据复制方式 的问题,如果按照数据一致性 从弱到强 来进行划分,有以下 3 种复制方式。

          方法1:异步复制

          image.gif编辑

          方法2:半同步复制

          image.gif编辑

          方法3:组复制

          异步复制和半同步复制都无法最终保证数据的一致性问题,半同步复制是通过判断从库响应的个数来决定是否返回给客户端,虽然数据一致性相比于异步复制有提升,但仍然无法满足对数据一致性要求高的场景,比如金融领域。MGR 很好地弥补了这两种复制模式的不足。

          组复制技术,简称 MGRMySQL Group Replication)。是 MySQL 5.7.17 版本中推出的一种新的数据复制技术,这种复制技术是基于 Paxos 协议的状态机复制。

          MGR 是如何工作的

          首先我们将多个节点共同组成一个复制组,在执行读写(RW)事务的时候,需要通过一致性协议层(Consensus 层)的同意,也就是读写事务想要进行提交,必须要经过组里“大多数人”(对应 Node 节点)的同意,大多数指的是同意的节点数量需要大于 (N/2+1),这样才可以进行提交,而不是原发起方一个说了算。而针对只读(RO)事务则不需要经过组内同意,直接 COMMIT 即可。

          image.gif编辑

          MGR MySQL 带入了数据强一致性的时代,是一个划时代的创新,其中一个重要的原因就是MGR 是基于 Paxos 协议的。Paxos 算法是由 2013 年的图灵奖获得者 Leslie Lamport 1990 年提出的。事实上,Paxos 算法提出来之后就作为 分布式一致性算法 被广泛应用,比如

          Apache ZooKeeper 也是基于 Paxos 实现的。


          分享到此,感谢大家观看!!!

          如果你喜欢这篇文章,请点赞关注吧,或者如果你对文章有什么困惑,可以私信我。

          🏓🏓🏓

          相关实践学习
          如何在云端创建MySQL数据库
          开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
          全面了解阿里云能为你做什么
          阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
          相关文章
          |
          18天前
          |
          SQL 关系型数据库 MySQL
          说一下MySQL主从复制的原理?
          【8月更文挑战第24天】说一下MySQL主从复制的原理?
          45 0
          |
          19天前
          |
          存储 关系型数据库 MySQL
          实战!MySQL主从复制一键搭建脚本分享
          实战!MySQL主从复制一键搭建脚本分享
          26 2
          |
          20天前
          |
          SQL 关系型数据库 MySQL
          在Linux中,mysql 如何减少主从复制延迟?
          在Linux中,mysql 如何减少主从复制延迟?
          |
          23天前
          |
          SQL 关系型数据库 MySQL
          Mysql原理与调优-事务与MVCC
          【8月更文挑战第19天】
          |
          26天前
          |
          存储 SQL 关系型数据库
          深入MySQL锁机制:原理、死锁解决及Java防范技巧
          深入MySQL锁机制:原理、死锁解决及Java防范技巧
          |
          1月前
          |
          SQL 关系型数据库 MySQL
          配置MySQL主从复制(一主一从)
          配置MySQL主从复制(一主一从)
          |
          2月前
          |
          存储 SQL 关系型数据库
          (六)MySQL索引原理篇:深入数据库底层揭开索引机制的神秘面纱!
          《索引原理篇》它现在终于来了!但对于索引原理及底层实现,相信大家多多少少都有了解过,毕竟这也是面试过程中出现次数较为频繁的一个技术点。在本文中就来一窥`MySQL`索引底层的神秘面纱!
          187 5
          |
          18天前
          |
          关系型数据库 MySQL 网络安全
          MySQL主从复制详细教程
          配置MySQL的主从复制是一个细致的过程,需要仔细遵循上述步骤进行。一旦配置完成并运行正常,主从复制将大大提高数据库的可用性和读写性能。在操作过程中,务必保持谨慎,确保数据的一致性和安全性。
          62 0
          |
          1月前
          |
          关系型数据库 MySQL PHP
          开发者必看:MySQL主从复制与Laravel读写分离的完美搭配
          开发者必看:MySQL主从复制与Laravel读写分离的完美搭配
          53 2
          |
          1月前
          |
          SQL canal 关系型数据库
          (二十四)全解MySQL之主从篇:死磕主从复制中数据同步原理与优化
          兜兜转转,经过《全解MySQL专栏》前面二十多篇的内容讲解后,基本对MySQL单机模式下的各方面进阶知识做了详细阐述,同时在前面的《分库分表概念篇》、《分库分表隐患篇》两章中也首次提到了数据库的一些高可用方案,但前两章大多属于方法论,并未涵盖真正的实操过程。接下来的内容,会以目前这章作为分割点,开启MySQL高可用方案的落地实践分享的新章程!
          529 1

          热门文章

          最新文章