美文网首页
第二十九节、MySQL是怎么保证主备一致的?

第二十九节、MySQL是怎么保证主备一致的?

作者: 小母牛不生产奶 | 来源:发表于2020-06-17 15:41 被阅读0次

    MySQL能够成为现下最流行的开源数据库,binlog功不可没;在最开始,MySQL是以容易学习和方便的高可用架构为优势,几乎所有的高可用架构,都直接依赖于binlog。虽然这些高可用架构已经呈现出越来越复杂的趋势,但都是从最基本的一主一备演化过来。

    主备原理

    主备流程图

    从上图可以看到:主库接收到客户端的更新请求后,执行内部事务的更新逻辑,同时写binlog。

    备库B跟主库A之间维持了一个长连接。主库A内部有一个线程,专门用于服务备库B的这个长连接。一个事物日志同步的完整过程是这样:

    1、在备库B上通过change master 命令,设置主库A的IP、端口、用户名、密码,以及要从哪个位置开始请求binlog,这个位置包含文件名和日志偏移量。

    2、在备库B上执行start slave 命令,这时候备库会启动两个线程,就是图中的io_thread和sql_thread。其中io_thread负责与主库建立连接。

    3、主库A校验完用户名、密码后,开始按照备库B传过来的位置,从本地读取binlog,发给B。

    4、备库B拿到binlog后,写到本地文件,称为中转日志(relay log)。


    binlog的三种格式

    statement:

    row:

    mixed

    相关文章

      网友评论

          本文标题:第二十九节、MySQL是怎么保证主备一致的?

          本文链接:https://www.haomeiwen.com/subject/pxmgmqtx.html