当前位置: 首页 > news >正文

MySQL事务原理

事务原理

  • 持久性是通过 redo log (重做日志)来保证的;

  • 原子性是通过 undo log(回滚日志) 来保证的;

  • 隔离性是通过 MVCC(多版本并发控制) 或锁机制来保证的;

  • 一致性则是通过持久性+原子性+隔离性来保证;

事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要么同时败。具有ACID四大特征。

原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。(还有约束) 隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。 持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

原子性,一致性,持久性这三大特性由 redo log 和 undo log 日志来保证的。【一致性是通过原子性、隔离性和持久性这三个特性来共同保障的】

隔离性 是由锁机制和MVCC保证的。

隔离性对应的隔离级别:RU、RC、RR、Serializeble

redo log:(持久性)

InnoDB特有,有他才有事务的概念

重做日志,记录的是事务提交时数据页的物理修改,是用来实现事务的持久性。 该日志文件由两部分组成:重做日志缓冲(redo log buffer)以及重做日志文件(redo log file),前者是在内存中,后者在磁盘中。当事务提交之后会把所有修改信息都存到该日志文件中,用于在刷新脏页到磁盘,发生错误时,进行数据恢复使用。

事务提交会把redologBuffer的数据页变更刷新到磁盘的redolog中】

个人理解: 事物每次提交的时候都会刷到磁盘redo log中,而不是直接将buffer pool中的数据直接刷到磁盘中(ibd文件中),是因为redo log 是顺序写,性能处理的够快,直接刷到ibd中,是随机写(随机IO性能低),性能慢。所以脏页是在下一次读的时候,或者后台线程采用一定的机制进行刷盘到ibd中。【WAL先写日志机制】 比如update的id跨度大,索引存储,所以随机写(很多数据,数据在磁盘中分散)很慢,要搞个顺序写(在磁盘一直往后写),写内存最快

undo log: (原子性)

回滚日志,用于记录数据被修改前的信息,作用包含两个:提供回滚和MVCC(多版本并发控制)。 undo log和redo log记录物理日志不一样,它是逻辑日志。可以认为当delete一条记录,undo log中会记录一条对应的insert记录,反之亦然,当update一条记录时,它记录一条对应相反的update记录。当执行rollback时,就可以从undo log中的逻辑记录读取到相应的内容并进行回滚

Undo log销毁:undo log在事务执行时产生,事务提交时,并不会立即删除undo log,因为这些日志可能还用于MVCC。 Undo log存储:undo log采用段的方式进行管理和记录,存放在前面介绍的rollback segment回滚段中,内部包含1024个undo log segment。???

一致性 + 总结:

MVCC 靠 隐藏字段 , undo log 版本链 , read view 实现的。

  • 原子性-undo log

  • 持久性-redo log

  • 一致性-undo log + redo log

  • 隔离性-锁 + MVCC

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • fastjson序列化对象后属性变更问题
  • SQL Chat:从SQL到SPEAKL的数据库操作新纪元
  • 战略引领下的成功产品开发之路
  • Tomcat源码解析(八):一个请求的执行流程(附Tomcat整体总结)
  • MATLAB 论文绘图规范标注
  • 地理信息系统(ArcGIS)在水文水资源、水环境中的实践技术应用及案例分析教程
  • 减少GPU显存的策略
  • 视觉SLAM十四讲:从理论到实践(Chapter8:视觉里程计2)
  • 公有云服务器部署springboot工程详细步骤
  • QT 和VS 针对linux开发的不同
  • 41 mysql subquery 的实现
  • GNU/Linux - 使用字符设备来操作GPIO
  • Redis与缓存失效策略:实现高效的数据过期处理
  • 13. ESP32-HTTPClient(Arduino)
  • 从零实现ChatGPT:第三章实现大型语言模型(1)
  • python3.6+scrapy+mysql 爬虫实战
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • ES学习笔记(12)--Symbol
  • HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
  • iBatis和MyBatis在使用ResultMap对应关系时的区别
  • JAVA SE 6 GC调优笔记
  • JS题目及答案整理
  • Linux Process Manage
  • nodejs实现webservice问题总结
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • Spring Cloud中负载均衡器概览
  • supervisor 永不挂掉的进程 安装以及使用
  • 大整数乘法-表格法
  • 如何选择开源的机器学习框架?
  • 如何用Ubuntu和Xen来设置Kubernetes?
  • 深入浅出Node.js
  • 算法-图和图算法
  • 微信小程序实战练习(仿五洲到家微信版)
  • 一道闭包题引发的思考
  • 一起参Ember.js讨论、问答社区。
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 说说我为什么看好Spring Cloud Alibaba
  • 移动端高清、多屏适配方案
  • ​520就是要宠粉,你的心头书我买单
  • $L^p$ 调和函数恒为零
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (C#)获取字符编码的类
  • (DFS + 剪枝)【洛谷P1731】 [NOI1999] 生日蛋糕
  • (zhuan) 一些RL的文献(及笔记)
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (阿里云万网)-域名注册购买实名流程
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (回溯) LeetCode 46. 全排列
  • (三)Kafka 监控之 Streams 监控(Streams Monitoring)和其他
  • (十)c52学习之旅-定时器实验
  • (转)大型网站架构演变和知识体系
  • (转载)利用webkit抓取动态网页和链接
  • * 论文笔记 【Wide Deep Learning for Recommender Systems】
  • .NET 5种线程安全集合
  • .NET MAUI Sqlite数据库操作(二)异步初始化方法