日志相关问题:
1. 在两阶段提交的不同瞬间, mysql如果发生异常重启, 怎么保证数据的完整性?
两阶段示意图
image.png
2....在时刻B中, binlog写完之后, mysql崩溃, 这时候由于binlog已经写入, 之后就会被从库(或者用这个binlog恢复出来的库)使用,所以主库再恢复的时候, 也要提交这个事务, 这样保证了主库和备份库的数据一致性...两阶段提交是典型的分布式系统的问题, 并不是mysql独有的
举个栗子....问题大意是, 只保留binlog, 将提交流程改成: "数据更新到内存" --> "写binlog" --> "提交事务" 是不是也具有了crash-safe能力....但是,InnoDB 引擎使用的是 WAL 技术,执行事务的时候,写完内存和日志,事务就算完成了。如果之后崩溃,要依赖于日志来恢复数据页。