binlog是Server层的归档日志,没有crash-safe能力
两种日志的不一样:
1.redo log是InnoDB引擎特有的;binlog是Server层实现的,全部引擎均可以使用
2.redo log是物理日志,记录的是 “在某个数据页上作了什么修改”;binlog是逻辑日志,记录的是这个语句的原始逻辑,好比 “给ID=2这一行的c字段加1”
3.redo log是 循环写的,空间固定会用完;binlog是 能够追加写入的。“追加写”是指binlog 文件写到必定大小后会切换到下一个,并不会覆盖之前的日志.net
1.执行器先找引擎去ID=2这行,ID是主键,引擎用树搜索找到这行,若是内存存在数据,直接返回给执行器,不然须要先从磁盘读入内存,再返回
2.执行器拿到引擎给的行数据,将该值加上1,获得新的一行数据,再调用引擎接口写入这行新数据
3.引擎将这行新数据更新到内存,同时将更新操做记录到redo log,redo log处于prepare状态,而后告知执行器执行完了,随时能够提交事务。
4.执行器生成这个操做的binlog,并把binlog写入磁盘
5.执行器调用引擎的提交事务接口,引擎把刚刚写入的redo log改为提交(commit)状态,更新完成日志
redo log和binlog均可以用于表示事务的提交状态,而两阶段提交就是让这两个状态保持逻辑上的一致blog