0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MySQL三种日志讲解

马哥Linux运维 来源:马哥Linux运维 2023-07-25 11:15 733次阅读

前言

MySQL 日志包含了错误日志、查询日志、慢查询日志、事务日志、二进制日志等,如果存储引擎使用的是 InnoDB ,二进制日志(binlog)和事务日志(包括redo log和undo log) 是肯定绕不过去的,本篇接下来详细为大家介绍这三种日志。

redo log

为什么要有 redo log ?

我们都清楚,事务的四大特性其中有一个是持久性,简单的说就是只要事务提交成功,对数据库做的修改就会被永久保存下来,不会因为任何原因再回到原来的状态。

MySQL 是怎么样保证持久性的呢?最简单的做法是在每次事务提交的时候,将该事务涉及修改的数据页全部刷新回磁盘中,可是这么做存在严重的性能问题:

单个事务可能涉及修改多个数据页,并且数据页在物理上并不连续,使用随机IO写入性能太差。

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进行配置,如下图所示:

11a928f4-29ff-11ee-a368-dac502259ad0.png

bin log

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强制刷到磁盘

bin log 和 redo log 都用于记录的修改之后的值,那么它们之间究竟有什么区别呢?

redo log 和 binlog 的区别

主要有以下三方面:

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

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

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

undo log

数据库事务四大特性中有一个是原子性,原子性指对数据库的一系列操作,要么全部成功,要么全部失败,不可能出现部分成功的情况。实际上,原子性底层就是通过undo log实现的。

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

undo log 同时也是MVCC(多版本并发控制)实现的关键。

总结

redo log是InnoDB存储引擎的一种日志,主要作用是崩溃恢复,刷盘策略参数 innodb_flush_log_at_trx_commit 推荐设置成2。

binlog是MySQL Server层的一种日志,主要作用是归档。

undo log是InnoDB存储引擎的一种日志,主要作用是回滚。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 磁盘
    +关注

    关注

    1

    文章

    374

    浏览量

    25200
  • MySQL
    +关注

    关注

    1

    文章

    804

    浏览量

    26521
  • 日志
    +关注

    关注

    0

    文章

    138

    浏览量

    10639
  • binlog
    +关注

    关注

    0

    文章

    7

    浏览量

    1250

原文标题:还分不清bin log 、redo log 跟 undo log?

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    相关推荐

    三种电源转换器电路设计讲解

      本文主要介绍了3.3V→5V电平转换器、模拟增益电路和模拟补偿电路三种电源转换器的设计原理图,对电路图进行简单的讲解。  3.3V→5V电平转换器可以直接构成电平转换,往往是采用集成方案。有
    发表于 09-30 16:26

    MySQL的六个日志类型

    MySQL日志管理
    发表于 04-24 16:57

    STM32的三种boot模式介绍

    浅识STM32的三种boot模式文章目录浅识STM32的三种boot模式任务摘要一、认识boot1.三种BOOT模式介绍2.开发BOOT模式选择3.STM32三种启动模式4.
    发表于 12-10 07:46

    半导体极管的三种基本放大电路的三种连接法电路图

    半导体极管的三种基本放大电路的三种连接法电路图
    发表于 05-06 14:55 5593次阅读
    半导体<b class='flag-5'>三</b>极管的<b class='flag-5'>三种</b>基本放大电路的<b class='flag-5'>三种</b>连接法电路图

    三种不同的“防 Ping”技巧

    三种不同的“防 Ping”技巧 浅析三种不同的“防 Ping”方法   众所周知,Ping命令是一个非常有用的网络命令,大家常用它
    发表于 04-14 13:53 1125次阅读

    晶体管放大电路的三种方法

    模拟电子技术中晶体管放大电路的方法有三种,PPT简单讲解
    发表于 03-24 14:34 0次下载

    jdbc注册驱动的三种方式

    本文主要介绍了关于jdbc注册驱动的三种方式。jdbc中注册驱动,首先导入对应的包,例如mysql-connector-java-5.0.8-bin.jar。驱动包是java和具体数据库之间的连接
    的头像 发表于 02-06 11:04 5957次阅读
    jdbc注册驱动的<b class='flag-5'>三种</b>方式

    详谈MySQL数据库的不同日志和源码

    任何一数据库,都会拥有各种各样的日志mysql也不例外。
    的头像 发表于 07-02 16:52 2581次阅读

    MySQL事务日志

    大家都清楚,日志MySQL 数据库的重要组成部分,记录着数据库运行期间各种状态信息。MySQL 日志主要包括「错误日志」、「查询
    的头像 发表于 11-14 09:58 1721次阅读
    <b class='flag-5'>MySQL</b>事务<b class='flag-5'>日志</b>

    80C51的三种复位技术讲解资料下载

    电子发烧友网为你提供80C51的三种复位技术讲解资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文资料、英文资料、参考设计、用户指南、解决方案等资料,希望可以帮助到广大的电子工程师们。
    发表于 04-08 08:46 9次下载
    80C51的<b class='flag-5'>三种</b>复位技术<b class='flag-5'>讲解</b>资料下载

    详解MySQL日志的作用

    MySQL日志 主要包括错误日志、查询日志、慢查询日志、事务日志、二进制
    的头像 发表于 07-22 14:44 1329次阅读

    基于mysql自有方式采集获取监控数据

    我们常听 MySQL 中有二进制日志 binlog、中继日志 relaylog、重做回滚日志 redolog、undolog 等。针对慢查询,还有一
    发表于 12-30 10:56 404次阅读

    如何优化MySQL中的join语句

    mysql中,join 主要有Nested Loop、Hash Join、Merge Join 这三种方式,我们今天来看一下最普遍 Nested Loop 循环连接方式,主要包括三种
    的头像 发表于 04-24 17:03 806次阅读
    如何优化<b class='flag-5'>MySQL</b>中的join语句

    mysql主从复制三种模式

    MySQL主从复制是一常见的数据同步方式,它可以实现将一个数据库的更改同步到其他多个数据库的功能。主从复制可以提高数据库的可用性和性能,以及提供故障恢复和数据备份的支持。在MySQL中,有
    的头像 发表于 11-16 14:04 1504次阅读

    systemd journal收集日志三种方式

    随着 systemd 成了主流的 init 系统,systemd 的功能也在不断的增加,比如对系统日志的管理。Systemd 设计的日志系统好处多多,这里笔者就不再赘述了,本文笔者主要介绍 systemd journal 收集日志
    的头像 发表于 10-23 11:50 217次阅读
    systemd journal收集<b class='flag-5'>日志</b>的<b class='flag-5'>三种</b>方式