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

第 57 期:MySQL 清理 undo log 居然用了 10 个小时

问题 undo log 长时间处于清理状态导致备份失败 问题现象:有客户反映有 3 套 MGR 环境全备失败,MySQL 版本为 8.0.18 ,Xtrabackup 版本为 8.0.9 。...Allocated tablespace ID 12 for zxc/a, old maximum was 0 Undo tablespace number 1 was being truncated...在该问题中,通过排查发现 undo log 过了 10 个小时依然没有清理完,正常情况下不会出现该情况,而是由于参数 super_read_only 触发的 bug 导致的。...可以通过调大 innodb_max_undo_log_size 参数,undo log 大小达到阈值前被 purge 掉,这样空间可以重用,很难达到阈值,所以不会触发 undo log truncate...问题原文:《故障分析 | undo log 长时间处于清理状态导致备份失败》 第三方大模型对比:ChatGPT-4o 因为在问题中给到了版本的信息,所以 ChatGPT 就会往版本的方向上引导,同时也给出来一些解决方案但是粒度较为粗糙

10610

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

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

    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链表。

    45010

    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(保证一致性);

    11410

    MySQLundo日志介绍

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

    1.8K20

    故障分析 | undo log 长时间处于清理状态导致备份失败

    处理方法也很简单重启一下备份的从节点 undo log 恢复正常,重新备份成功。 虽然暂时已经解决了备份的问题,但不能总是重启来解决。接下来重点看看 undo log 清理的问题。...查看 error log 信息,发现在 00:48 已经开始清理 undo log ,备份是在凌晨1点开始,参数 innodb_max_undo_log_size 设置为 1G ,正常的话应该也能清理完...log 空间,发现 undo_1_trunc.log、undo_2_trunc.log 还在说明 undo log 过了10个小时依然没有清理完。...等了半小时 undo_1_trunc.log 与 undo_2_trunc.log 依然存在。但主节点 undo log 清理的很快。...这也解释了为什么在主节点上 undo log 清理的很快。 那有什么办法减少触发这个 bug 呢?我们可以将 innodb_max_undo_log_size 调大。

    1.4K10

    🍑 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.2K31

    MySQL 日志:undo log、redo log、binlog

    大家好,我是田哥 今天来和大家分享MySQL的三个日志文件,可以说 MySQL 的多数特性都是围绕日志文件实现,而其中最重要的有以下三种: redo 日志 undo 日志 binlog 日志 比如更新语句的流程会涉及到...在事务没提交之前,MySQL 会先记录更新前的数据到 undo log 日志文件里面,当事务回滚时,可以利用 undo log 来进行回滚。...事务处理过程中,如果出现了错误或者用户执 行了 ROLLBACK 语句,MySQL 可以利用 undo log 中的历史数据将数据恢复到事务开始之前的状态。...undo log 为每条记录保存多份历史数据,MySQL 在执行快照读(普通 select 语句)的时候,会根据事务的 Read View 里的信息,顺着 undo log 的版本链找到满足其可见性的记录...不过,在修改该 Undo 页面前需要先记录对应的 redo log,所以先记录修改 Undo 页面的 redo log ,然后再真正的修改 Undo 页面。

    2.3K43

    MySQL 8.0.21中UNDO截断的改进

    作者:Kevin Lewis 译:徐轶韬 UNDO表空间可以在MySQL 8.0中隐式或显式截断。两种方法使用相同的机制。当UNDO表空间截断完成时,可能导致非常繁忙的系统上的定期停顿。...此问题已在MySQL 8.0.21中修复。 首先,让我们了解可用于防止UNDO表空间过大的两种方法。 隐式截断 默认情况下,隐式方法在MySQL 8.0中为ON。...当与UNDO表空间中的UNDO日志关联的所有事务都已完成,并且不再需要该空间中的所有UNDO日志来保护数据完整性时,就可以将表空间截断了。 之后删除表空间,并创建一个新的UNDO表空间来替换它。...’; 详细内容请参阅在线手册https://dev.mysql.com/doc/refman/8.0/en/innodb-undo-table和一个博客文章https://mysqlserverteam.com...因此,在MySQL 8.0.21中,在删除了关联的撤消数据文件之后,InnoDB现在将那些页面留在缓冲池中。InnoDB知道这些页面用于已删除的表空间ID。由于页面变得很少使用,它们将被动释放。

    1.3K30
    领券