首页 > 其他分享 >bin log 、redo log 跟、undo log

bin log 、redo log 跟、undo log

时间:2023-07-30 15:46:02浏览次数:39  
标签:bin binlog log 记录 磁盘 日志 redo

MySQL 日志包含了错误日志、查询日志、慢查询日志、事务日志、二进制日志等,如果存储引擎使用的是 InnoDB ,二进制日志(binlog)和事务日志(包括redo log和undo log)

# redo log(用于记录的修改之后的值)=====》针对持久性

MySQL 是怎么样保证持久性:

在每次事务提交的时候,将该事务涉及修改的数据页全部刷新回磁盘中,可是这么做存在严重的性能问题:
  1. 单个事务可能涉及修改多个数据页,并且数据页在物理上并不连续,使用随机IO写入性能太差。
  2. Innodb是以页为单位进行磁盘交互的,一个事务有可能只会修改一个数据页中的几个字节,如果这时候将完整的数据页刷回磁盘的话,很浪费资源。

因此 MySQL 设计出了redo log,当一条记录更新的时候, InnoDB 引擎会先把记录写到 redo log 里面去,同时更新内存,这样就算这条数据更新成功了,完美地解决了性能问题(文件更小并且是顺序IO)。

注意此时数据并没有更新到磁盘上,InnoDB 会在恰当的时候把这条记录更新到磁盘上去。这种先写日志然后再将数据刷盘的机制,有个专有名词——WAL(Write-ahead logging)

redo log 刷到磁盘

redo log包含两部分:

  • 内存中的日志缓冲(redo log buffer)

  • 磁盘上的日志文件(redo log file)

 

每执行一条DML语句,数据库先将记录写入redo log buffer,然后后续某个时间点再一次性将多个操作记录写到redo log file。MySQL 一共支持三种写入redo log file的时机,通过参数 innodb_flush_log_at_trx_commit 进行配置

 

# bin log(用于记录的修改之后的值)=====《针对server进行记录》

bin log 是 MySQL 的逻辑日志,由Server层进行记录,用于记录数据库执行的写入性操作(不包括查询)信息,以二进制的形式保存在磁盘中。无论你使用的是任何的存储引擎,mysql数据库都会记录binlog日志

与redo log日志一样,binlog也有自己的刷盘策略,通过sync_binlog参数控制:
  • 0 :每次提交事务前将binlog写入os cache,由操作系统控制什么时候刷到磁盘

  • 1 :采用同步写磁盘的方式来写binlog,不使用os cache来写binlog

  • N :当每进行n次事务提交之后,调用一次fsync() os cache中的binlog强制刷到磁盘

 

redo log 和 binlog 的区别

主要有以下三方面:

  1. binlog 是 MySQL 的 Server 层实现的,所有的引擎都是可以的。redo log是InnoDB的日志。如果不使用InnoDB引擎,是没有redo log的。

  2. binlog是逻辑日志,记录的是对哪一个表的哪一行做了什么修改;redo log是物理日志,记录的是对哪个数据页中的哪个记录做了什么修改,可以理解为对磁盘上的哪个数据做了修改。

  3. redo log 是有固定大小的,所以它的空间会用完,如果用完的话,一定要进行一些写入磁盘的操作才可以继续; binlog 是可以追加写入的,也就是 binlog 没有空间的概念,一直写就行了

 

# undo log(用于记录数据的逻辑变化) =======针对事务的原子性

undo log主要记录了数据的逻辑变化,比如一条UPDATE语句,对应一条相反UPDATE的undo log,一条INSERT语句,对应一条DELETE的undo log,这样在发生错误时,就能回滚到事务之前的数据状态。

# 总结

  • redo log是InnoDB存储引擎的一种日志,主要作用是崩溃恢复,刷盘策略参数 innodb_flush_log_at_trx_commit 推荐设置成2。
  • binlog是MySQL Server层的一种日志,主要作用是归档。
  • undo log是InnoDB存储引擎的一种日志,主要作用是回滚。

 

标签:bin,binlog,log,记录,磁盘,日志,redo
From: https://www.cnblogs.com/KL2016/p/17591520.html

相关文章

  • m基于双PN序列的数据帧检测,帧同步verilog实现,含testbench
    1.算法仿真效果本系统进行Vivado2019.2平台的开发,其中Vivado2019.2仿真结果如下:2.算法涉及理论知识概要基于双PN序列的数据帧检测和帧同步是一种在通信系统中常用的技术,用于确保接收端正确地识别和解析传输的数据帧。在本文中,我将详细介绍基于双PN序列的数据帧检测的数学原理和......
  • log4j2配置需要
    在resource中建立log4j2.xml文件进行配置查看代码<?xmlversion="1.0"encoding="UTF-8"?><configuration><loggers><!--level指定日志级别,从低到高的优先级:TRACE<DEBUG<INFO<WARN<ERROR......
  • m基于UW序列的数据帧检测,帧同步verilog实现,含testbench
    1.算法仿真效果本系统进行了Vivado2019.2平台的开发,仿真结果如下所示:2.算法涉及理论知识概要UW序列是一种特殊类型的伪随机二进制序列,通常用于数据帧检测和帧同步。UW序列具有以下特性:平衡性:UW序列中的1和0的数量大致相等,确保序列具有良好的自相关性。低互相关:不同UW序列之间......
  • m基于双PN序列的数据帧检测,帧同步verilog实现,含testbench
    1.算法仿真效果 本系统进行Vivado2019.2平台的开发,其中Vivado2019.2仿真结果如下:   2.算法涉及理论知识概要       基于双PN序列的数据帧检测和帧同步是一种在通信系统中常用的技术,用于确保接收端正确地识别和解析传输的数据帧。在本文中,我将详细介绍基于双PN......
  • m基于UW序列的数据帧检测,帧同步verilog实现,含testbench
    1.算法仿真效果 本系统进行了Vivado2019.2平台的开发,仿真结果如下所示:   2.算法涉及理论知识概要      UW序列是一种特殊类型的伪随机二进制序列,通常用于数据帧检测和帧同步。UW序列具有以下特性: 平衡性:UW序列中的1和0的数量大致相等,确保序列具有良好的自相......
  • springboot logback 配置文件 自定义logback配置文件
    logging:level:#配置全部的调试级别#root:trace#配置具体包路径下的调试级别com.example.springboot03:tracepattern:#默认控制台输出格式console:'%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-ddHH:mm:ss.SSSXXX}}){faint}%clr(${LOG_......
  • 关于使用Qt.labs.platform在arch中报错 ERROR: No native FileDialog implementation
    当跟着QtBook的章节QtQuickControls编写一个ImageViewer,运行时报错:ERROR:NonativeFileDialogimplementationavailable.QtLabsPlatformrequiresQtWidgetsonthissetup.Add'QT+=widgets'to.proandcreateQApplicationinmain().尝试过搜索在cmake中引入Q......
  • 无涯教程-jQuery - Dialog组件函数
    小部件对话框函数可与JqueryUI中的小部件一起使用。对话框是在HTML页面上显示信息的一种不错的方法。对话框是一个带有标题和内容区域的浮动窗口。此窗口可以移动,调整大小,并且默认情况下可以使用"X"图标关闭。Dialog-语法$("#dialog").dialog();Dialog-示例以下是显示......
  • log4j反序列化漏洞
    Vulhub-Docker-Composefileforvulnerabilityenvironment1、介绍名称:nginx解析漏洞编号:原理:应用:log4j版本:2、测试2.1靶场搭建2.2 ysoserial:JAVA反序列化POC生成工具(gitee.com)......
  • Hello cnblog!
      Hellocnblog!2023-07-2922:16:58星期六Hellocnblog!print("Hello")Hellocnblog!TestHellocnblog!cnblogblogmyfirstcnblogmyfirstblogstazxr.cnHellocnblog!$x^2$\[\intx^2dx\]111abcabcwebsite......