一:前言

  - 前面通过 《Mysql 事务 - 隔离》 的学习,知道了事务的实现,是根据 获取一致性视图 来实现的。

二:那么,什么时候会获取到一致性视图呢?

  - 例如:有三个事务,启动的详情如图(autocommit = 1)

  - 

  - 事务 A,B,C 查到的值是多少呢?

    - 事务 B 查到的 k 的值是 3,而事务 A 查到的 k 的值是 1

  

  - 理解

    - begin/start transaction 命令并不是一个事务的起点,在执行到它们之后的第一个操作 InnoDB 表的语句,事务才真正启动

 

三:一致性视图的实现?

  - 在可重复读隔离级别下,事务在启动的时候就“拍了个快照”。注意,这个快照是基于整库的。

  - 这时,你会说这看上去不太现实啊。如果一个库有 100G,那么我启动一个事务,MySQL 就要拷贝 100G 的数据出来,这个过程得多慢啊。可是,我平时的事务执行起来很快啊。

  - 这就引入了 InnoDB 的 MVCC 概念。

四:多版本并发控制(MVCC)

  - 概念

    - Mysql 的大多数事务存储引擎实现的都不是简单的行级锁,一般都实现了 MVVC(多版本并发控制)

    - 不同的引擎对于MVCC的实现不同,典型的有(乐观并发控制/悲观并发控制)

   原理

    - 通过保存数据在某点的快照实现,也是就说,不过执行多长时间,每个事务看到的数据都是一致的。

    - 也就是说,事务的开始时间不同,对于同一张表,同一时刻看的的数据可能是不同的。

  - 详解

    你真的懂MVCC吗?来手动实践一下?

  - MVCC 流程 - 以 REPEATTABLE  READ (可重复读 - 隔离级别)举例

    - SELECT

      - InnoDB 只会查找版本早于当前事务版本的数据行,可以保证事务读取的行

      - 要么是在事务开始前已经存在的。

      - 要么是在事务自身插入或者修改过的。

      - 行的删除版本要么未定义,要么大与当前事务版本号这样可以确保事务读取到的行,在事务开始未被删除。

     - INSERT

      - 为新插入的一行保存当前的系统版本号作为行版本号。

    - DELETE

      - 为删除的一行保存当前的系统版本号作为行删除标识

    - UPDATE

      - 新插入一行记录,保存当前系统版本号作为行版本号。

      - 同时保存当前系统的版本号到原来的行,作为行删除标识。

  - 注意点

    - 保存着两个版本号,使得大多数的读操作都不需要加锁。

    - 这样的设计使得读数据更简单,性能很好,并且也能保证只会读到符合标准的行。

    - 不足是每行记录都需要额外的存储空间,需要做更多的维护工作。

    - 目前 MVCC 只工作在 读已提交/可重复读 两个隔离级别下

      - 读未提交 总会读取最新的行

      - 串行化则会对所有读取到的行加锁。

五:附录

  • * mysql> show table status like 'tblwechatTemplate' \G;
    * *************************** . row ***************************
    * Name: tblwechatTemplate
    * 表名
    * Engine: InnoDB
    * 引擎
    * Version:
    * Row_format: Dynamic
    * 行模式
    * Rows:
    * 表中的行数
    * 对于 MyIsam 和其他是准确的
    * 对于 InnoDB 是估计值
    * Avg_row_length:
    * 平均每行包含的字节
    * Data_length:
    * 表数据的大小
    * Max_data_length:
    * 表数据的最大容量,和存储引擎有关
    * Index_length:
    * 索引大小(字节)
    * Data_free:
    * Auto_increment:
    * 下个自增主键的值
    * Create_time: -- ::
    * 表创建时间
    * Update_time: -- ::
    * 表数据最后修改时间
    * Check_time: NULL
    * Collation: utf8_general_ci
    * 默认字符集和排序规则
    * Checksum: NULL
    * Create_options:
    * Comment: 模板消息模板id记录表

《Mysql - 事务 MVCC》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. mysql中 where与having的区别

    having子句与where有相似之处但也有区别,都是设定条件的语句.在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行.而where子句在查询过程中执行优 ...

  2. ROS与树莓派的结合

    从零开始学树莓派和ROS 今天写下自己的第一篇博客,记录一下自己的学习历程和学习过程中碰到的各种小问题,供同道者参阅和自己以后回顾用 ,水平不高,我就放开手写吧,反正也不会有人看. 我现在在做毕业设计 ...

  3. P1613 跑路——倍增思想,floyd

    https://www.luogu.org/problemnew/show/P1613 他有一个跑路机器,每次只能跑2k   (单位)路程,每相邻两个点的路程为1,也就是说如果连边1——>2—— ...

  4. $.extend和$.fn.extend详解

    一.定义 $.extend()属于j全局的Query对象,用于将一个或多个对象合并到目标对象上: $.fn.extend()属于jQuery的原型对象,用于在jQuery原型上扩展实例属性和方法. 二 ...

  5. Java基础系列 - 查找数组的最大值和最小值

    package com.test6; public class test5 { public static void main(String[] args) { int[] arr = {1, 2, ...

  6. Js 之生成二维码插件(jquery.qrcode.js)

    一.下载 链接:https://pan.baidu.com/s/1cMjaCYQ_buZNT5XRRjuNTA提取码:myqm 二.效果图 三.代码 <!DOCTYPE html> < ...

  7. Spring家族主流成员介绍

    摘 要:Spring 就像一个大家族,有众多衍生产品例如 Boot,Security,JPA等等.但他们的基础都是Spring 的 IOC 和 AOP,IOC提供了依赖注入的容器,而AOP解决了面向切 ...

  8. sql 从服务器取消主从复制

    mysql>change master to master_host='' mysql>stop slave;reset slave;

  9. Java List 和 Array 转化

    List to Array List 提供了toArray的接口,所以可以直接调用转为object型数组 List<String> list = new ArrayList<Stri ...

  10. 使用Flask构建机器学习模型API

    1. Python环境设置和Flask基础 使用"Anaconda"创建一个虚拟环境.如果你需要在Python中创建你的工作流程,并将依赖项分离出来,或者共享环境设置," ...