首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 日志(redo log 和 undo log) 都是什么鬼?

MySQL 系列知识点我都整理成面试题了带全部答案,关注公众号Java技术栈回复面试获取。 二进制日志是在存储引擎的上层产生的,不管是什么存储引擎,对数据库进行了修改都会产生二进制日志。...幂等性的意思是多次操作前后状态是一样的,例如新插入一行后又删除该行,前后状态没有变化。而二进制日志记录的是所有影响数据的操作,记录的内容较多。例如插入一行记录一次,删除该行又记录一次。...在此处需要注意一点,一般所说的log file并不是磁盘上的物理日志文件,而是操作系统缓存中的log file,官方手册上的意思也是如此(例如:With a value of 2, the contents...在MySQL5.7中该变量已经移除。 2.undo log 2.1 基本概念 undo log有两个作用:提供回滚和多个行版本控制(MVCC)。...有时候应用到行版本控制的时候,也是通过undo log来实现的:当读取的某一行被其他事务锁定时,它可以从undo log中分析出该行记录以前的数据是什么,从而提供该行版本信息,让用户实现非锁定一致性读取

1.5K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql undo文件解析(2)

    可使用如下代码快速得到回滚段的PAGE ID信息import structfilename = '/data/mysql_3314/mysqldata/undo_001'with open(filename...有兴趣的可以去看mysql源码: storage/innobase/trx/trx0rec.cc验证还是来使用代码进行愉快的验证吧.我们显示开启一个事务, 先不提交然后我们使用ibd2sql的debug...到这里了还是会有点成就感的, 但不多.总结mysql会自己去使用undo, 即使undo有问题了,重新初始化就行, 所以undo一般不咋重视. 后续也不在对undo进行解析了....如下为完整的undo文件结构图.参考: https://github.com/mysql/mysql-serverhttps://dev.mysql.com/doc/refman/8.0附源码github...:{undo_slot}")def _argparse():parser = argparse.ArgumentParser(add_help=True, description='解析mysqlundo

    22920

    Undo日志--mysql详解(十)

    Undo日志 如何保证事务里的原子性,当数据执行到一半需要回滚,或者数据库发生宕机,这时候就需要保证事务原子性,所以回滚应该只有发生新增,修改,删除时候才考虑,select并没有回滚操作。...这里除了trx_id外,还有roll_pointer,他本质上就是一个指针,指向对应的undo日志。...一种是更新主键的情况,会对该记录先进行delete mark操作,之后再插入新的数据,也就是说,每次都会产生两条undo log。...我们前面说过表空间是很多页组成,fil_page_index存储聚簇索引二级索引, fil_page_type_fsp_hdr存储表空间头部信息,这里存的就是fil_page_undo_log。...Undo日志是分为两大类,一类是可以提交直接删除,一类还是为了mvcc服务。在undo日志中,每个页分类不同的链表连接起来,insert undo,update undo链表。

    44110

    MySQLundo日志介绍

    MySQLundo日志介绍 概念介绍: 我们知道,MySQL中的redo日志记录了事务的行为,在服务器宕机的时候,可以通过重做事务来达到恢复数据的目的,然而,有的时候,事务还有回滚的需求,也就是说...,undo日志的段位于共享表空间内。...删除方式: 还有一点需要注意,事务共享表空间中写入undo日志的过程同样需要写入redo日志,事务一旦提交,也就意味着事务的持久性生效,那么undo日志则不被需要,但是innodb并不会把这个undo...日志直接删除,而是放在一个undo日志的链表中,到底什么时候删除取决于mysql的purge线程,这样做是为了避免其他的事务需要通过undo日志来得到这条记录之前的版本。...,具体的方法是,事务提交的时候,现将undo页放入链表中,然后判断这个undo页的使用空间是否小于75%,如果是的话,那么这个undo页就可以被重用,之后的undo日志就可以追加在当前undo日志的后面

    1.8K20

    Mysql-4-redo、undo、binlog

    https://www.jianshu.com/p/20e10ed721d01、binlog(归档日志):MySQL 自带的日志模块,是一个二进制格式的文件,用于"记录用户对数据库更新的SQL语句信息"...主要作用:主从复制、数据恢复2、undo_log(回滚日志):用于保证数据的原子性,记录数据修改之前的数据,可以用于回滚(记录旧数据) 主要作用:事务回滚、实现多版本控制...主要作用:当有增删改相关的操作时,会先记录到 Innodb 中,并修改缓存页中的数据, 等到 mysql 闲下来的时候才会真正的将 redolog...2、undo log:主要记录的是数据的逻辑变化,为了在发生错误时回滚之前的操作,需要将之前的操作都记录下来,然后在发生错误时才可以回滚。...undo log的作用: 1、用于事务的回滚(保证原子性); 2、用于MVCC(保证一致性);

    11010

    🍑 MySQL事务日志 undo log 详解

    (对于每个UPDATE,InnoDB存储引擎会执行一个相反的UPDATE,将修改前的行放回去) MySQL把这些为了回滚而记录的这些内容称之为撤销日志或者回滚日志(即undo log)。...此外,undo log会产生redo log,也就是undo log的产生会伴随着redo log的产生,这是因为undo log也需要持久性的保护。...2.Undo 日志作用: 作用一:回滚数据 用户对undo日志可能有误解:undo用于将数据库物理地恢复到执行语句或事务之前的样子。但事实并非如此。...3.Undo 日志存储结构: 回滚段与undo页: InnoDB对undo log管理采用段的方式,也就是回滚段(Rollback Segment)。...每个回滚段记录了1024个undo log segment,而在每个undo log segment段中进行undo页的申请。

    1.1K31
    领券