zoukankan      html  css  js  c++  java
  • MySQL复制原理

    参考官网:https://dev.mysql.com/doc/refman/5.7/en/replication-implementation-details.html

    MySQL复制功能是通过三个线程实现的,包括主上的binlog dump tread和从上的sql thread、I/O ttread

    Binlog dump thread

    master创建binlog dump thread,用于 当slave连接到master时发送binlog events给其,dump thread每次读取将要发送给slave的每个event时

    先获得lock在binary log,读完之后再 释放。

    Slave I/O thread

    当执行 START SLAVE 在slave端执行后,slave会创建I/O thread  连接到master主动读取dump thread将最新的binlog events写到本地的relay log中

    Slave SQL thread

    slave创建SQL thread从relay log中读取event并应用

    I/O thread读取event的速度并不因为server执行的慢而变慢,即使slave的I/O thread 停止一会,当再次开启的时候也能迅速的获取master中所有

    最新的binlog内容到relay log,即使SQL thread有很大的延迟。如果slave在SQL thread运用完所有的relay log之前停止了,I/O thread至少获取到

    了到目前为止在master上所发生的所有事务日志到relay  log,保证安全复制,到slave 下次启动时接着应用。

    如果maser  通过show processlist看不到binlog dump thread,则说明复制已经停了。

  • 相关阅读:
    golang 使用错误总结
    golang 跨平台交叉编译
    golang redis 第三方包
    golang 浮点型 与其他数值类型计算
    golang 更友好的格式化输出
    golang 指定长度 随机数 & 随机字符串
    go语言中int和byte转换方式
    基础知识
    golang bytes 包 详解
    golang 解析 ini 文件 中文文档
  • 原文地址:https://www.cnblogs.com/Bccd/p/7163128.html
Copyright © 2011-2022 走看看