17.1.2 Replication Formats
复制格式
17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication
17.1.2.2 Usage of Row-Based Logging and Replication
17.1.2.3 Determination of Safe and Unsafe Statements in Binary Logging
复制工作因为events被写入到binary log 是从master读取然后在slave上处理。
events 是记录在binary log 有不同的格式根据event的类型。
不同的复制格式用于对应的binary logging 格式用于当时间是被记录到master的binary log.
1.当使用基于statement-based binary logging, master写SQL语句到binary log.
master的复制到slave工作通过执行SQL语句在slave上。这个称为给予语句的复制(SBR),
2.当使用基于行格式的记录,master 写events 到binary log 表明表示单个表的记录被改变。
master的复制到slave 通过复制events 表明表记录的改变到slave.
在 row-based replication, master 写events 到binary log 表明单个表记录的改变
3.你也可以配置MySQL 来使用statement-based and row-based的混合记录,
取决于 哪个是最合适的用于记录改变. 这个被称为混个日志记录。
当使用mixed-format logging, 一个基于语句的log 是默认被使用。
依赖某些语句,和使用的存储引擎, log是自动切换到基于行的在特定的例子。
在MySQL 5.6,基于语句是默认的
MySQL Cluster. 默认的binary logging 格式在所有的MySQL Cluster NDB 7.3 and MySQL Cluster NDB 7.4 releases is MIXED.
你应该注意MySQL Cluster 复制总是使用基于行的复制,NDB 存储引擎是不兼容tatement-based replication.
当使用混合格式时, binary loging 格式是取决于使用的存储引擎和被执行的语句。