开发者社区> 问答> 正文
1
0
分享

MySQL的复制原理以及流程?

MySQL的复制原理以及流程?

展开
收起
请回答1024 2020-03-31 11:35:08 768 0
举报
飞天免费试用计划
领取免费云资源,开启云上实践第一步
云数据库 RDS MySQL
集群系列 2核4GB
额度3个月内有效
RDS MySQL Serverless 基础系列
0.5-2RCU 50GB
额度3个月内有效
RDS MySQL Serverless 高可用系列
价值2615元额度,1个月
额度1个月内有效
1 条回答
写回答
取消 提交回答
  • 主从复制:将主数据库中的DDL和DML操作通过二进制日志(BINLOG)传输到从数据库上,然后将这些日志重新执行(重做);从而使得从数据库的数据与主数据库保持一致。

    主从复制的作用

    • 主数据库出现问题,可以切换到从数据库。
    • 可以进行数据库层面的读写分离。
    • 可以在从数据库上进行日常备份。

    MySQL主从复制解决的问题

    • 数据分布:随意开始或停止复制,并在不同地理位置分布数据备份
    • 负载均衡:降低单个服务器的压力
    • 高可用和故障切换:帮助应用程序避免单点失败
    • 升级测试:可以用更高版本的MySQL作为从库

    MySQL主从复制工作原理

    • 在主库上把数据更高记录到二进制日志
    • 从库将主库的日志复制到自己的中继日志
    • 从库读取中继日志的事件,将其重放到从库数据中

    **基本原理流程,3个线程以及之间的关联 ** 主:binlog线程——记录下所有改变了数据库数据的语句,放进master上的binlog中;

    从:io线程——在使用start slave 之后,负责从master上拉取 binlog 内容,放进自己的relay log中;

    从:sql执行线程——执行relay log中的语句;

    复制过程

    5.jpg

    Binary log:主数据库的二进制日志

    Relay log:从服务器的中继日志

    第一步:master在每个事务更新数据完成之前,将该操作记录串行地写入到binlog文件中。

    第二步:salve开启一个I/O Thread,该线程在master打开一个普通连接,主要工作是binlog dump process。如果读取的进度已经跟上了master,就进入睡眠状态并等待master产生新的事件。I/O线程最终的目的是将这些事件写入到中继日志中。

    第三步:SQL Thread会读取中继日志,并顺序执行该日志中的SQL事件,从而与主数据库中的数据保持一致。

    2020-03-31 11:36:46 举报
    赞同 评论 打赏

    评论

    全部评论 (0)

    登录后可评论
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等