说说mysql主从同步怎么做的吧

原理:

1.master库提交完事务,写入binlog;

2.slave库连接到master库,获取binlog;

3.master创建dump线程,向slave推送binlog;

4.slave开启一个IO线程读取master中推送过来的binlog,并同步到自己的中继日志relaylog中;

5.slave再开启一个sql线程,将relaylog数据写入自己的数据库;

6.slave记录自己的binlog日志;

由于mysql默认的复制方式是异步的,主库把日志发送给从库后不关心从库是否已经处理,这样会产生一个问题就是假设主库挂了,从库处理失败了,这时候从库升为主库后,日志就丢失了。由此产生两个概念。

全同步复制

主库写入binlog后强制同步日志到从库,所有的从库都执行完成后才返回给客户端,但是很显然这个方式的话性能会受到严重影响。

半同步复制

和全同步不同的是,半同步复制的逻辑是这样,从库写入日志成功后返回ACK确认给主库,主库收到至少一个从库的确认就认为写操作完成。

问:主从复制延迟该怎么办?

这个无解,关键的数据就配置从主库读取呗;

posted @ 2020-11-05 17:40  瞌睡青年  阅读(111)  评论(0)    收藏  举报