• MVCC究竟是什么?


    1.MVCC概念

    MVCC,全称多版本并发控制
    MVCC究竟是什么?
    通俗的来说MVCC就是为了在读取数据时不加锁来提高读取效率的一种办法,MVCC解决的是读写时线程安全问题,线程不用去抢占读写锁。MVCC中的读就是快照读,也就是普通的select语句。

    2.MVCC原理

    mvcc的具体实现通过数据库中的三个隐式字段、undolog、readview

    其中三个隐式字段分别是:

    1. DB_TRX_ID:最近修改事务ID
    2. DB_ROLL_PTR:回滚指针,指向这条记录上一个版本,用于配合undolog,指向上一个版本
    3. DB_ROW_ID:隐藏主键,如果表结果没有指定主键,将会生成该隐藏字段

    undolog(回滚日志):

    在insert、update、delete的时候产生便于数据回滚的日志

    readview(读视图):

    是快照读SQL执行时MVCC提取数据的依据(通俗的来说就是select的时候我们需要知道可以读取哪个版本下的数据),记录并维护当前活跃的事务,read view中包含四个核心字段

    1. m_ids:当前活跃的事务ID集合
    2. min_trx_id:最小活跃事务ID
    3. max_trx_id:预分配事务ID,当前最大事务ID+1(因为事务ID是自增的)
    4. creator_trx_id:readview创建者的事务ID

    readview中规定了版本链的访问规则,trx_id表示当前事务id:

    • 1.trx_id==creator_trx_id:可以访问该版本,说明数据是当前这个事务更改的
    • 2.trx_id可以访问,说明数据已经提交了
    • 3.trx_id>max_trx_id:不可以访问,说明事务时在readview生成之后才开启的
    • 4.min_trx_id<=trx_id<=max_trx_id:如果trx_id不在m_idx中,是可以访问该版本的,说明数据已经提交

    不同的隔离级别生成readview的时机不同:

    • read committed:在事务每执行一次快照时生成readview
    • repeatable read:仅在同一事务第一次快照读时生成readview,后续复用该readview,所以每次读取的结果都一样
  • 相关阅读:
    C++——内联函数|auto关键字
    SpringMvc(三、REST风格快速入门
    es6解构用法
    【Netty】nio处理accept&read&write事件
    左(6)hash,大数据,位运算
    hive01--hive的安装及配置
    图像识别神经网络算法,神经网络图像识别技术
    爬虫之selenium
    设计模式桥接模式
    国际期货投机有什么风险?目前正大怎么样?
  • 原文地址:https://blog.csdn.net/qq_41277195/article/details/132638268