Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL主从同步原理及应用

MySQL主从同步原理及应用

作者:Java烘焙师

日常工作中,MySQL数据库是必不可少的存储,其中读写分离基本是标配,而这背后需要MySQL开启主从同步,形成一主一从、或一主多从的架构。本篇文章我们就来解绍MySQL主从同步原理及应用,需要的朋友可以参考一下

1、主从同步原理

主从同步架构图(异步同步)

这是最常见的主从同步架构

主从同步流程(异步同步)

什么是binlog?

主库每提交一次事务,都会把数据变更,记录到一个二进制文件中,这个二进制文件就叫binlog。需注意:只有写操作才会记录至binlog,只读操作是不会的(如selectshow语句)。

binlog的3种格式

statement格式:binlog记录的是实际执行的sql语句
row格式:binlog记录的是变化前后的数据(涉及所有列),形如update table_a set col1=value1, col2=value2 ... where col1=condition1 and col2=condition2 ...
mixed格式:默认选择statement格式,只在需要时改用row格式

binlog格式对比

主从同步的2种方式

主从同步流程(半同步)

半同步适用场景

高可用备份:半同步复制,可确保从库与主库的一致性,当主库发生故障时,切换到从库不会丢失数据。为了保证稳定性(不因半同步慢而拖累主库),一般不承担业务流量、尽可能快地ack,只用于同步备份。

2、主从同步应用场景

普通场景:线上从库异步同步,高可用备份半同步

对一致性要求较高的大数据取数需求

大数据取数可能导致从库cpu使用率飙升、ack变慢,可设置半同步所需ack数量为1,正常情况下高可用备份能很快ack,于是主库会commit并返回,而大数据取数复制慢一些也无所谓。这样就不会因为大数据取数ack慢而影响主库和业务了。

到此这篇关于MySQL主从同步原理及应用的文章就介绍到这了,更多相关MySQL主从同步原理及应用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文