上一篇文章介绍了MySQL主从同步的原理和利用,本文总结了MySQL主从提早的起因和解决办法。如果主从提早过大,会影响到业务,该当采纳适合的解决方案。

MySQL主从提早的体现

先insert或update写入更新操作,再立刻select查问,然而得不到最新的后果。
可通过show slave status命令,后果中的Seconds_Behind_Master列,查看主从提早的秒数。

MySQL主从提早的起因

  1. 读写拆散时,写操作走主库,读操作走从库,然而主库的变更还未同步至从库
  2. 网络传输提早:从库发动dump申请,主库推送binlog文件,从库写入本地relay log
  3. 从库串行执行sql语句:主库并发的事务提交,然而在从库上只能串行执行,速度比主库慢

MySQL主从提早解决办法

业务优化

如果业务场景容许,先写入更新操作,期待一小段时间后再查问。比方,新增一条记录,前端成心提早半秒再调后端接口查问。

技术优化

  • 拆库+并行复制:MySQL反对库级别的并行复制,拆库后每个分库的数据质变小,主从提早天然也变小了。
  • 慢sql优化除慢sql,也能升高主从提早

    终结计划

    以上方法治标不治本,只能起到缓解主从提早的作用,彻底根治还需这么做。

  • 显式查主库:不同的分片中间件做法不一样,client侧分片可在每次查问前设置查主库的标记(ThreadLocal变量),proxy侧分片开启事务
    长处:实现简略,毛病:受MySQL QPS限度,QPS极高时不举荐
  • 双写数据库和缓存,查缓存:防止MySQL主从提早
    长处:可撑持高并发场景