日常工作中,MySQL数据库是必不可少的存储,其中读写分离基本是标配,而这背后需要MySQL开启主从同步,形成一主一从、或一主多从的架构,掌握主从同步的原理和知道如何实际应用,是一个架构师的必备技能。楼主将在本文做总结,看这一篇就够了。
1、主从同步原理
主从同步架构图(异步同步)
这是最常见的主从同步架构。
主从同步流程(异步同步)
- 主库把数据变更写入binlog文件
- 从库I/O线程发起dump请求
- 主库I/O线程推送binlog至从库
- 从库I/O线程写入本地的relay log文件(与binlog格式一样)
- 从库SQL线程读取relay log并重新串行执行一遍,得到与主库相同的数据
什么是binlog?
主库每提交一次事务,都会把数据变更,记录到一个二进制文件中,这个二进制文件就叫binlog。需注意:只有写操作才会记录至binlog,只读操作是不会的(如select、show语句)。