亲宝软件园·资讯

展开

MySQL主从同步原理及应用 MySQL主从同步原理及应用

Java烘焙师 人气:0
想了解MySQL主从同步原理及应用的相关内容吗,Java烘焙师在本文为您仔细讲解MySQL主从同步原理及应用的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点: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慢而影响主库和业务了。

加载全部内容

相关教程
猜你喜欢
用户评论