row模式
行模式。对于ddl,会把每一条记录的变更记录下来。dml会记录执行的sql语句。
现在有一些业务需要获取数据的变更change feed capture,就需要使用row模式。
statement模式
语句模式。不管是ddl还是dml,记录的都是sql语句,被记录下来的同时还有一些上下文信息。当执行sql语句的时候,由于每台机器的环境不一样,容易出现数据不致的问题,执行结果不可控。
mixed
混合模式。会根据具体的SQL语句选择使用row和还是statement。update table_name set name="Jhon" where user_id=1;
这条语句起作用的只有一条记录,使用row模式。update table_name set name="Jhon";
这条语句执行的记录条数不确定,使用statement模式。
但是当binlog因为一些原因要回放执行的时候会出问题,它会把后来新加入的记录也都给修改了。所以存在风险,需要谨慎使用。
综上,最安全最简单的模式是row模式。缺点是数据量大的时候,会产生很多日志,占用大量磁盘空间。
可以在运行时修改复制模式mysql> SET SESSION binlog_format = 'ROW';