本文更新于2020-05-04,使用MySQL 5.7,操作系统为Deepin 15.4。
复制是指将主库的DDL和DML操作通过二进制日志传到从库上,然后从库对这些日志重做,从而使得主库和从库的数据保持同步。
复制的优点有:
MySQL通过3个线程来完成主从库间的数据复制:其中Binlog Dump线程跑在主库上,I/O线程和SQL线程跑在从库上。可通过SHOW PROCESSLIST
查看线程的状态。
MySQL的复制是主库主动推送日志到从库去的。复制过程涉及两类非常重要的日志文件:二进制日志文件(Binlog)和中继日志文件(Relay Log)。中继日志文件的文件格式、内容和二进制日志文件一样,区别在于其在执行完后会自动删除。
为了保证从库崩溃后,从库的I/O线程和SQL线程仍能知道从哪里开始复制,从库默认还会创建两个日志文件master.info和relay-log.info,分别记录了I/O线程当前读取主库二进制日志的进度和SQL线程应用中继日志的进度。通过SHOW SLAVE STATUS
可查看当前从库复制的状态。
MySQL支持4种复制模式:基于SQL语句的复制(SBR)、基于行数据的复制(RBR)、混合复制(对安全的SQL采用SBR,对非安全的SQL使用RBR)、使用全局事务ID(GTIDs)的复制。
MySQL支持3种日志格式:基于SQL语句的日志格式(SBL)、基于行数据的日志格式(RBL)、混合格式。
复制的常见架构有:
复制方式有两种:异步复制、半同步复制。
暂略。
参与评论
手机查看
返回顶部