MySQL主从复制

简介

        由于在实际的生产环境中,由单台MySQL数据库服务器不能满足实际的需要,此时数据库集群就很好地解决了这个问题。采用MySQL分布式集群,能搞搭建一个高并发、负载均衡的集群服务器。但是,如果保证这些服务器之间数据与数据的完整性呢?MySQL数据库自身提供的主从复制功能可以方便的实现数据的多处自动备份,实现数据库的拓展。

        下图是一个多个数据库主从复制的模型(图片来自网络)
在这里插入图片描述
        在一主多从的数据库体系中,多个从服务器采用异步的方式更新主数据库的变化业务服务器在执行写或者相关修改数据库的操作是在主服务器上进行的,读操作则是在各个从服务器上进行。

主从复制的原理

        MySQL主从复制需要三个线程:master(binlog dump thread)、slave(I/O thread、SQL thread)

        master(主服务器):主服务器中使用的是 dump thread线程。当主库中有数据更新时,主库就会根据设置的binlog格式,将更新的事件类型写入到主库的binlog文件中,此时主库会创建log dump线程通知slave(从服务器)有数据更新,当I/O线程请求日志内容时,会将此时的binlog名称和当前更新的位置同时传给从服务器的IO线程。

        slave(从服务器):从服务器中使用I/O线程、SQL thread.

  • I/O线程:该线程会连接到主数据库上,向log dump请求一份指定binlog文件位置的副本,并将请求回来的binlog存到本地的relay log中,relay log和binlog日志一样也是记录了数据更新的事件,它也是按照递增后缀名的方式,产生多个relay log文件,slave会使用一个index文件来追踪当前正在使用的relay log文件。
  • SQL线程:该线程检测到relay log有更新后,会读取并在本地做redo操作,将发生在主库的事件在本地重新执行一遍,来保证主从数据同步,此外,如果一个relay log文件中的全部事件都执行完毕,那么SQL线程会自动将relay log文件删除掉。

        下图是整个过程的原理图:

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值