MySQL能够成为现下最流行的开源数据库,binlog功不可没;在最开始,MySQL是以容易学习和方便的高可用架构为优势,几乎所有的高可用架构,都直接依赖于binlog。虽然这些高可用架构已经呈现出越来越复杂的趋势,但都是从最基本的一主一备演化过来。
主备原理
从上图可以看到:主库接收到客户端的更新请求后,执行内部事务的更新逻辑,同时写binlog。
备库B跟主库A之间维持了一个长连接。主库A内部有一个线程,专门用于服务备库B的这个长连接。一个事物日志同步的完整过程是这样:
1、在备库B上通过change master 命令,设置主库A的IP、端口、用户名、密码,以及要从哪个位置开始请求binlog,这个位置包含文件名和日志偏移量。
2、在备库B上执行start slave 命令,这时候备库会启动两个线程,就是图中的io_thread和sql_thread。其中io_thread负责与主库建立连接。
3、主库A校验完用户名、密码后,开始按照备库B传过来的位置,从本地读取binlog,发给B。
4、备库B拿到binlog后,写到本地文件,称为中转日志(relay log)。
binlog的三种格式
statement:
row:
mixed