MySQL(十三)binglog 和 redo log

一.什么是两阶段提交

binlog

1.binlog又叫归档日志。
2.binlog是MySQL Server层的日志,而不是存储引擎自带的日志,它记录了所有的DDL和DML(不包含查询)语句,而且是以事件形式记录,还包含语句所执行的消耗的时间。
3.binlog是一种逻辑日志,他里面所记录的是一条SQL语句的原始逻辑,例如给某一个字段+1(区别于redo log的物理日志。物理日志:在某个数据页上做了什么修改)。
4.binlog文件写满后,会自动切换到下一个日志文件继续写,而不会覆盖以前的日志。,redo log 是循环写入的,即后面写入的可能会覆盖前面写入的。
5.配置 binlog 的时候,尽量指定binlog的有效期,这样使文件在到期后,日志文件会自动删除。

redo log

binlog是MySQL自己提供的,redo log 是存储引擎InnoDB提供的。

因为 Innodb 是以页为单位进行磁盘交互的,而一个事务很可能只修改一个数据页里面的几个字节,这个时候将完整的数据页刷到磁盘的话,不仅效率低,也浪费资源。效率低是因为这些数据页在物理上并不连续,将数据页刷到磁盘会涉及到随机 IO。写 redo log 与写磁盘 IO不同的是 redo log 是顺序 IO,而写数据涉及到随机 IO,写数据需要寻址,找到对应的位置,然后更新/添加/删除,而写 redo log 则是在一个固定的位置循环写入,是顺序 IO,所以速度要高于写数据。

而redo log 本身又分为:

  1. 日志缓冲(redo log buffer),该部分日志是易失性的
  2. 重做日志 (redo log file) ,这是磁盘上的日志文件,该部分日志是持久的。

MySQL 每执行一条 DML 语句,先将记录写入 redo log buffer ,后续在某个时间点再一次性将多个操作记录写到 redo log file ,这种先写日志再写磁盘的技术就是 MySQL 里经常说到的 WAL(Write-Ahead Logging) 技术(预写日志)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值