Java常见技术分享-28-事务安全-事务日志-事务日志流程

前情提要

在简单认识了一下事务日志的框架之后, 我们需要做的是把整个流程窜起来, 先用个简单的例子。

案例 把id=1 的用户余额从100改成200
  • 当执行更新操作的时候, innodb 会先把数据从磁盘读到内存的缓冲池。
  • 先记录 undo log , 把 id =1 的用户余额 = 100 这个信息保存下来。
    • 这样一来, 如果后面事务出错需要回滚, 就能通过这里的记录进行恢复。
  • 接着引擎会在内存把这个账户的余额改成200 。
  • 接着 记录redo log , 内容 大概是 "ID =1 的用户 的余额 改成 200 这个操作"
    • 这样就算数据库突然崩溃, 内存里边的修改丢了, 重启后也能通过这个记录,重新执行一遍操作。
  • 最后在整个事务提交的时候, mysql 会把这次的修改记录到binlog 了。内容同样是"ID =1 的用户 的余额 改成 200 这个操作"
    • 服务器层面的日志,让从库知道 主库做了哪些修改
总结
  • 记 undo log 备份回滚
    • 管理范围 在 提交成功之前 ,崩溃了, 事务处于未提交的状态 出了问题 都回滚 就需要这个undo log
  • 再记 redo log 保证持久性
    • 管理范围 在提交成功之后 ,崩溃了, 事务处于已提交状态, 出了问题 就通过redo log 恢复数据
      • 需要注意的是 在 事务提交过程中 redo log buffered(redo log 不是每次操作都刷 而是先记录到内存的buffered 批量刷新) 就会被强制刷到 磁盘 如果 刷失败了 也算提交失败
  • 最后事务提交 记 binlog 供同步。

补充

  • MyISAM存储引擎 没有undo log 或者 redo log 所以他不支持事务

  • 存储引擎 可以理解为 Mysql的数据处理发动机,他负责怎么存储数据, 如何建立索引, 怎么处理事务。 设计成可插拔的存储引擎架构, 而不是自己一条龙昨晚, 主要是应对不同的业务需求。

相关推荐
小bo波2 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯4 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
SamDeepThinking14 小时前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好15 小时前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程
MacroZheng16 小时前
短短几天,暴涨2.8万Star!又一款编程神器开源!
java·人工智能·后端
SamDeepThinking16 小时前
函数式编程:用BiFunction消除多类型分支的代码重复
java·后端·面试
Flittly1 天前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了1 天前
Java 生成二维码解决方案
java·后端
人活一口气2 天前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP2 天前
Vibe Coding -- 完整项目案例实操
java