`

mysql replication原理介绍

阅读更多

要想用好一个系统,理解其实现原理是非常重要的事情,只有理解了其实现原理,我们才能够扬长避短,合理的利用,才能够搭建出最适合我们自己应用环境的系统,才能够在系统实施之后更好的维护他。MySQL Replication 可以说是在目前 MySQL 数据库的实际应用场景中最为常见的Scale Out 手段了,这里就针对其实现原理做一个简单的分析。
  一、 Replication 线程
  Mysql的 Replication 是一个异步的复制过程,从一个 Mysql instace(我们称之为 Master)复制到另一个 Mysql instance(我们称之 Slave)。在 Master 与 Slave 之间的实现整个复制过程主要由三个线程来完成,其中两个线程(Sql线程和IO线程)在 Slave 端,另外一个线程(IO线程)在 Master 端。
  要实现 MySQL 的 Replication ,首先必须打开 Master 端的Binary Log(mysql-bin.xxxxxx)功能,否则无法实现。因为整个复制过程实际上就是Slave从Master端获取该日志然后再在自己身上完全顺序的执行日志中所记录的各种操作。打开 MySQL 的 Binary Log 可以通过在启动 MySQL Server 的过程中使用 “—log-bin” 参数选项,或者在 my.cnf 配置文件中的 mysqld 参数组([mysqld]标识后的参数部分)增加 “log-bin” 参数项。
  MySQL 复制的基本过程如下:
  1. Slave 上面的IO线程连接上 Master,并请求从指定日志文件的指定位置(或者从最开始的日志)之后的日志内容;
  2. Master 接收到来自 Slave 的 IO 线程的请求后,通过负责复制的 IO 线程根据请求信息读取指定日志指定位置之后的日志信息,返回给 Slave 端的 IO 线程。返回信息中除了日志所包含的信息之外,还包括本次返回的信息在 Master 端的 Binary Log 文件的名称以及在 Binary Log 中的位置;
  3. Slave 的 IO 线程接收到信息后,将接收到的日志内容依次写入到 Slave 端的Relay Log文件(mysql-relay-bin.xxxxxx)的最末端,并将读取到的Master端的bin-log的文件名和位置记录到master- info文件中,以便在下一次读取的时候能够清楚的高速Master“我需要从某个bin-log的哪个位置开始往后的日志内容,请发给我”
  4. Slave 的 SQL 线程检测到 Relay Log 中新增加了内容后,会马上解析该 Log 文件中的内容成为在 Master 端真实执行时候的那些可执行

分享到:
评论

相关推荐

    完整精品数据库课件 MySQL从入门到精通 第18章 MySQL Replication(共27页).ppt

    MySQL Replication是MySQL数据库系统中的一个重要特性,它允许数据从一个主服务器(master)自动同步到一个或多个从服务器(slaves)。...理解和掌握MySQL复制的原理及配置方法,是MySQL数据库管理员必备的技能之一。

    深入理解MySQL Group Replication

    ### 深入理解MySQL Group Replication #### 背景与定义 MySQL Group Replication是一种高可用性和可扩展性的解决方案,它通过在多个MySQL服务器之间自动同步数据来确保数据的一致性和可用性。该技术自MySQL 5.7.17...

    第18章 MySQL Replication PPT

    MySQL复制(Replication)是MySQL数据库系统中一种强大的功能,它允许数据从一个服务器(主服务器)异步地复制到一个...通过深入研究PPT资源,你可以更全面地了解MySQL Replication的工作原理、配置细节以及最佳实践。

    mysql replication修改库名及复制单个表

    在深入探讨如何通过MySQL Replication实现库名修改与单个表的复制之前,我们先来了解MySQL Replication的基本概念及其工作原理。MySQL Replication是一种数据复制机制,它允许从一台服务器(主服务器)向另一台或多...

    PyPI 官网下载 | mysql-replication-0.19.tar.gz

    2. **MySQL Replication原理** MySQL Replication是一种异步复制模式,主服务器上的更改被记录在binlog中,然后这些更改被从服务器读取并应用。`mysql-replication`库提供了读取binlog事件的API,使得开发者可以...

    MySQL Group Replication 组复制原理

    本文将详细介绍MySQL Group Replication的基本原理及其相关机制和服务。 #### 二、常见复制技术架构对比 ##### 1、传统异步复制 在传统异步复制中,主库在完成事务处理并将相关信息写入binlog后,无论从库是否成功...

    使用MMM实现MySQL Replication的高可用

    ### 使用MMM实现MySQL Replication的高可用 #### MMM (Master-Master Replication Manager for MySQL) MMM是一套灵活的脚本工具集,用于监控、故障转移和管理MySQL的Master-Master复制配置(仅允许一个节点可写)...

    python-mysql-replication-main.zip

    在IT行业中,数据库的复制是一项重要的技术,它用于在多个服务器之间同步数据,提高可用性和容错性。...在使用这个库时,需要结合对MySQL复制原理的理解和良好的编程实践,以确保系统的稳定性和可靠性。

    藏经阁-MySQL Replication Latest Developments.pdf

    这份“藏经阁-MySQL Replication Latest Developments”文档很可能详细介绍了MySQL复制技术的最新进展和创新。下面将深入探讨MySQL复制的基本概念、工作原理以及可能的新发展。 MySQL复制主要基于异步模式,这意味...

    藏经阁-Group Replication 原理解析与实践经验.pdf

    一、Group Replication原理 Group Replication是MySQL的一个高可用性解决方案,能够提供高性能、高可用性的数据库服务。其核心思想是通过分布式事务处理机制,实现多个节点之间的事务一致性和高可用性。 Group ...

    MySQL Replication 主从复制全方位解决方案

    通过本文的介绍,我们了解了MySQL主从复制的基本原理、二进制日志的管理以及主从复制的典型应用场景。掌握这些知识可以帮助我们在实际工作中更加高效地利用MySQL的主从复制特性,构建出更加健壮、可靠且具有高扩展性...

    MySQLReplication和Oraclelogicalstandby的原理对比

    MySQLReplication和Oraclelogicalstandby都是SQLapply,那么在实现上有何区别?MySQLReplication可以很方便的用来做应用的读扩展,也可以帮MySQL实现一定程度的HA方案整个复制过程实际上就是Slave从Master端抓取...

    Mysql 5.7 基于组复制(MySQL Group Replication) - 精华版

    本篇文章详细介绍了 MySQL 5.7 基于组复制(MySQL Group Replication)的配置说明,实为线上操作手册,在此分享,希望能帮助到有用到的朋友~ MySQL 组复制(MySQL Group Replication)是 MySQL 官方于 2016 年 12 月...

    MySQL 8数据库原理与应用徐丽霞微课版实训代码

    学习者将了解到主从复制的工作原理,以及如何设置和管理复制链路,以及MySQL Group Replication等高级复制技术。 总的来说,这个实训涵盖了MySQL 8数据库从基础到进阶的各个方面,通过实际操作和案例分析,旨在帮助...

    MySQL Replication(复制)提高可扩展性和可用性以及故障处理

    本篇文章将深入探讨MySQL复制的工作原理、配置过程、优势及故障处理策略。 **1. MySQL复制简介** MySQL复制是指一个主数据库(Master)的数据更改被记录并同步到一个或多个从数据库(Slaves)。这种架构允许数据的...

    Session_7_MySQL_Group_Replication_for_High_Availability

    #### MySQL Group Replication 的介绍 - **定义**:MySQL Group Replication 是一款用于 MySQL 的“更新所有位置”(update everywhere)复制插件,具有内置的自动分布式故障处理功能。 - **目标**:旨在通过一个...

Global site tag (gtag.js) - Google Analytics