笔记记录自林晓斌(丁奇)老师的《MySQL实战45讲》

3) --事务隔离,为什么你改了我还看不见?

  简单来说,事务就是要保证一组数据操作,要么全部成功,要么全部失败。在MySQL中,事务支持是在引擎层实现的。但并不是所有的引擎都支持事务,这也是MyISAM被InnoDB取代的重要原因之一。

  本篇内容均是在InnoDB下讨论。

  提到事务,总免不了ACID(Atomicity,Consistency,Isolation,Durability),(原子性,一致性,隔离性,持久性),本篇主要讨论的是隔离性。

  隔离性在MySQL中是分为不同的隔离级别的。包括 读未提交(read uncommitted),读提交(read commited),可重复读(repeatable read)(MySQL默认隔离级别),串行化(serializable)。隔离性依次增强。

  • 读未提交: 一个事务还没提交时,它所做的变更就能被别的事务看到。
  • 读提交: 一个事务提交之后,它所做的变更才能被别的事务看到。
  • 可重复读:一个事务的执行过程当中所能看到的数据,总是和这个事务启动时能看到的数据保持一致。当然在可重复读时,这个事务自身所做的变更对其他事务来说也是不可见的。
  • 串行化: 写会加“写锁”,读会加“读锁”,出现读写冲突时,后访问的事务必须等前一个事务执行完成,才能继续执行。

  

  (图片来源于 极客时间 林晓斌 《MySQL 实战45讲》,如有版权问题请联系我删除)

  以上图为例,在四种隔离级别下对应的情况分别为:

  • 读未提交:事务A启动时查询结果为1, V1时值为2(读到了事务B未提交的数据),V2时值为2,V3时值为2
  • 读提交:事务A启动时查询结果为1, V1时值为1(读不到事务B未提交的数据),V2时值为2(事务B已经提交,可以被事务A读到),V3时值为2
  • 可重复读:事务A启动时查询结果为1, V1时值为1(读不到事务B未提交的数据),V2时值为1(事务A未提交,在事务A过程内保持与事务A启动时读到的数据一致),V3时值为2(事务A已经提交)
  • 串行化:事务B在执行将1改成2时会被锁住,直到事务A提交后,事务B才可以继续执行。因此 V1,V2的值是1,V3的值是2.

  在实现上,数据库里会创建一个视图,访问的时候以视图的逻辑结果为准。 在“可重复读”下,这个视图是在事务启动时建立的。在“读提交”下,这个视图是在每个SQL语句开始执行的时候创建的。另:“读未提交”下,不创建视图,直接返回记录上的最新值。在“串行化”下使用加锁的方式来避免进行并行访问。

事务隔离级别的实现:

  以可重复读为例,假设将一个值从1案顺序改成2,3,4.在回滚日志里会有如下的记录。

  

  (图片来源于 极客时间 林晓斌 《MySQL 实战45讲》,如有版权问题请联系我删除)

  在MySQL中,实际上每条记录在更新的时候都会同时记录一条回滚操作,通过这个回滚操作可以获得更新前的记录。当前值是4,但是在查询这条记录时,不同时刻启动的事务会有不同的read-view. 同一条记录在系统中存在多个版本,这就是数据库的多版本并发控制(MVCC),对于A来说,要想得到1,就必须将当前所有操作依次回滚。即使这个时候有一个新的事务将4改成其他值,这个新的事务也和之前是事务没有冲突。每个事务被隔离开来了。

  当然,回滚操作的日志不会一直保留,直到系统中没有比这个回滚操作更早的read-view时就会删除回滚操作日志。因此当你使用长事务时,系统中可能会存在很古老的read-view视图,当然对应的回滚操作也不会删除,回滚日志就会变得很大。

上篇问题答案:

  请问在什么场景下,一天一次备份会比一周一次备份更有优势?或者说,它影响了这个数据系统的哪些指标?

  在一天一备份的情况下,最坏情况需要应用一天的binlog,一周一备份则会需要使用一周的binlog了。系统的对应指标就是 RTO(恢复目标时间)。当然也不是说一天一备份就完全优于一周一备份,因为频繁的全量备份需要消耗更多存储空间,需要根据具体业务来评估。

问题:

  如果你是数据库负责人,你有什么方案来避免长事务呢?

MySQL 笔记整理(3) --事务隔离,为什么你改了我还看不见?的更多相关文章

  1. mysql实战45讲 (三) 事务隔离:为什么你改了我还看不见 极客时间读书笔记

    提到事务,你肯定不陌生,和数据库打交道的时候,我们总是会用到事务.最经典的例子就是转账,你要给朋友小王转100块钱,而此时你的银行卡只有100块钱. 转账过程具体到程序里会有一系列的操作,比如查询余额 ...

  2. MySQL 笔记整理(8.b) --事务到底是隔离还是不隔离的?

    笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> (本篇内图片均来自丁奇老师的讲解,如有侵权,请联系我删除) 8.a) --事务到底是隔离还是不隔离的? 本周工作较忙,加上懒惰,拖更 ...

  3. 最全mysql笔记整理

    mysql笔记整理 作者:python技术人 博客:https://www.cnblogs.com/lpdeboke Windows服务 -- 启动MySQL net start mysql -- 创 ...

  4. 【原创】互联网项目中mysql应该选什么事务隔离级别

    摘要 企业千万家,靠谱没几家. 社招选错家,亲人两行泪. 祝大家金三银四跳槽顺利! 引言 开始我们的内容,相信大家一定遇到过下面的一个面试场景 面试官:"讲讲mysql有几个事务隔离级别?& ...

  5. MySQL数据库引擎、事务隔离级别、锁

    MySQL数据库引擎.事务隔离级别.锁 数据库引擎InnoDB和MyISAM有什么区别 大体区别为: MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能 ...

  6. 互联网项目中mysql应该选什么事务隔离级别

    引言 开始我们的内容,相信大家一定遇到过下面的一个面试场景 面试官:“讲讲mysql有几个事务隔离级别?” 你:“读未提交,读已提交,可重复读,串行化四个!默认是可重复读” 面试官:“为什么mysql ...

  7. 【转】互联网项目中mysql应该选什么事务隔离级别

    作者:孤独烟 转自:https://www.cnblogs.com/rjzheng/p/10510174.html 摘要 企业千万家,靠谱没几家.社招选错家,亲人两行泪. 祝大家金三银四跳槽顺利! 引 ...

  8. MySQL 笔记整理(7) --行锁功能:怎么减少行锁对性能的影响?

    笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> 7) --行锁功能:怎么减少行锁对性能的影响? MySQL的行锁是在引擎层由各个引擎自己实现的.因此,并不是所有的引擎都支持行锁,如 ...

  9. MySQL的四种事务隔离级别

    本文实验的测试环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做 ...

随机推荐

  1. UVALive 2474 Balloons in a Box(枚举)

    https://vjudge.net/contest/277824#problem/A 尤其是模拟题,三思而后敲!!! 纠错了好久,主要还是没有处理好:单点若还未放气球,其他气球可以膨胀越过它(即可以 ...

  2. go语言的for循环

    for循环是一个循环控制结构,可以执行指定次数的循环. 三种循环方式 第一种,常见的 for 循环,支持初始化语句 for init; condition; post { } init: 一般为赋值表 ...

  3. php调用第三方接口

    方式一 $url = 'http://ip.taobao.com/service/getIpInfo.php?ip='.$realip;$data = file_get_contents(" ...

  4. Floyd算法解决多源最短路问题

    说好的写dijkstra 算法堆优化版本的,但是因为,妹子需要,我还是先把Floyd算法写一下吧!啦啦啦! 咳咳,还是说正事吧! ----------------------------------- ...

  5. windows运维如何批量远程桌面

    作用:windows下批量管理远程桌面, http://www.appmazing.com/ 官方站点  http://www.appmazing.com/files/RDO_Setup.exe wi ...

  6. android studio 撤销和恢复

    我的Android studio版本是2.2版本 1.Ctrl+z是撤销快捷键 2.如果Ctrl+z 掉的内容,又反悔了,快捷键为:Ctrl + Shift + z.

  7. Java构造方法、成员变量初始化以及静态成员变量初始化三者的先后顺序是什么样的?

    [Java笔试真题]:构造方法.成员变量初始化以及静态成员变量初始化三者的先后顺序是什么样的? [解答]:当类第一次被加载的时候,静态变量会首先初始化,接着编译器会把实例变量初始化为默认值,然后执行构 ...

  8. [Swift]LeetCode397. 整数替换 | Integer Replacement

    Given a positive integer n and you can do operations as follow: If n is even, replace n with n/2. If ...

  9. [Swift]LeetCode583. 两个字符串的删除操作 | Delete Operation for Two Strings

    Given two words word1 and word2, find the minimum number of steps required to make word1 and word2 t ...

  10. [Swift]LeetCode845. 数组中的最长山脉 | Longest Mountain in Array

    Let's call any (contiguous) subarray B (of A) a mountain if the following properties hold: B.length ...