• 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) 技术(预写日志)。

  • 相关阅读:
    C++11 --- lambda表达式
    全栈开发提效神器——ApiFox(Postman + Swagger + Mock + JMeter)
    SQL UNION 运算符
    kafka如何保证消息不丢失?半分钟的答案和半个小时的答案有点不一样。
    Tomcat一机多实例部署
    css之字体属性和文字属性
    flutter开发实战-hero动画简单实现
    CesiumJS 2022^ 原理[5] - 着色器相关的封装设计
    优化 - 不要在for循环中调用数据库
    基于ubuntu tun虚拟网卡设备完成ping的发送与模拟接收
  • 原文地址:https://blog.csdn.net/weixin_43189971/article/details/126437152