1、什么是半一致性读

A type of read operation used for UPDATE statements, that is a combination of read committed and consistent read. When an UPDATE statement examines a row that is already locked, InnoDB returns the latest committed version to MySQL so that MySQL can determine whether the row matches the WHERE condition of the UPDATE. If the row matches (must be updated), MySQL reads the row again, and this time InnoDB either locks it or waits for a lock on it. This type of read operation can only happen when the transaction has the read committed isolation level, or when the innodb_locks_unsafe_for_binlog option is enabled.

就是发生在update语句中。在RC隔离级别或者innodb_locks_unsafe_for_binlog被设置为true,并发时,如果update的记录发生锁等待,那么返回该记录的prev 版本(在返回前会将锁等待的这个lock从trx中删除掉),到mysql层进行where判断,是否满足条件。如果满足where条件,那么再次进入innodb层,真正加锁或者发生锁等待。

这样做的好处是:减少同一行记录的锁冲突及锁等待;无并发冲突时,直接读取最新版本加锁,有冲突时,不加锁,读取prev版本不需要锁等待。

缺点:非冲突串行话策略,对于binlog来说是不安全的。只能发生在RC隔离级别和innodb_lock_unsafe_for_binlog下。

2、原理

3、讲解

1)半一致性读需要mysql层和innodb层配合使用。

2)mysql_update函数中,默认都会调用try_semi_consistent_read在RC或innodb_lock_unsafe_for_binlog下加上试图半一致性读标签:prebuilt->row_read_type = ROW_READ_TRY_SEMI_CONSISTENT。真正执行半一致性读是由innodb层决定。

3)半一致性读的条件:该记录发生锁等待;必须是全表扫描 && 该索引是二级索引

4)半一致性读时,构建prev版本,然后调用函数lock_trx_handle_wait将锁等待从trx中删除。

5)返回prev rec前,会将置成半一致性读标签:prebuilt->row_read_type = ROW_READ_DID_SEMI_CONSISTENT

6)返回到mysql层,会进行where判断。如果匹配,那么会再次进入innodb层,由于prebuilt->row_read_type == ROW_READ_DID_SEMI_CONSISTENT,此时不再走半一致性读判断的流程,直接进入加锁或锁等待。

5)这里update有个优化:innodb层如果执行计划是索引下推,那么判断where条件是否匹配会提前。若不匹配则提前调用函数row_unlock_for_mysql释放聚集索引上的锁

6)另外一个优化:返回mysql层后,判断where不匹配,则会调用unlock_row函数释放锁。注:这里update在innodb层没有发生锁冲突,成功加上了锁。即没有半一致性读

mysql 一致性读_MySQL半一致性读原理解析-从源码角度解析相关推荐

  1. 尖峰 mysql 源码方向_MySql轻松入门系列————第一站 从源码角度轻松认识mysql整体框架图...

    一:背景 1. 讲故事 最近看各大技术社区,不管是知乎,掘金,博客园,csdn基本上看不到有小伙伴分享sqlserver类的文章,看样子这些年sqlserver没落了,已经后继无人了,再写sqlser ...

  2. mysql command line client 目标不对_MySql轻松入门系列-第一站 从源码角度轻松认识mysql整体框架图...

    一:背景 1. 讲故事 最近看各大技术社区,不管是知乎,掘金,博客园,csdn基本上看不到有小伙伴分享sqlserver类的文章,看样子这些年sqlserver没落了,已经后继无人了,再写sqlser ...

  3. mysql源码_MySql轻松入门系列——第一站 从源码角度轻松认识mysql整体框架图

    一:背景 1. 讲故事 最近看各大技术社区,不管是知乎,掘金,博客园,csdn基本上看不到有小伙伴分享sqlserver类的文章,看来在国内大环境下是不怎么流行了,看样子我再写sqlserver是不可 ...

  4. java监听mysql某张表的insert操作_MySql轻松入门系列————第一站 从源码角度轻松认识mysql整体框架图

    一:背景 1. 讲故事 最近看各大技术社区,不管是知乎,掘金,博客园,csdn基本上看不到有小伙伴分享sqlserver类的文章,看样子这些年sqlserver没落了,已经后继无人了,再写sqlser ...

  5. mysql教程源码_MySql轻松入门系列————第一站 从源码角度轻松认识mysql整体框架图...

    一:背景 1. 讲故事 最近看各大技术社区,不管是知乎,掘金,博客园,csdn基本上看不到有小伙伴分享sqlserver类的文章,看样子这些年sqlserver没落了,已经后继无人了,再写sqlser ...

  6. MySQL怎么运行的系列(十一)快照读、锁定读、半一致性读 和 加锁语句分析

    本系列文章目录 展开/收起 MySQL怎么运行的系列(一)mysql体系结构和存储引擎 MySQL怎么运行的系列(二)Innodb缓冲池 buffer pool 和 改良版LRU算法 Mysql怎么运 ...

  7. 从源码角度来读Handler

    最近打算从源码角度来读一下Handler,MessageQueue,Message,Looper,这四个面试必考项.所以今天先从Handler开始. 一.Handler的作用 源码定义 There a ...

  8. 【Matlab协同任务】二阶一致性算法多无人机协同编队动态仿真【含源码 1740期】

    一.代码运行视频(哔哩哔哩) [Matlab协同任务]二阶一致性算法多无人机协同编队动态仿真[含源码 1740期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1 ...

  9. 读文章笔记(三):从源码学习Transformer

    读文章笔记(三):从源码学习Transformer encoder分为两部分: decoder 公众号机器学习算法工程师 文章链接: https://mp.weixin.qq.com/s/0NajB_ ...

最新文章

  1. DataWorks V2使用PyUdf
  2. 系列文章|OKR与敏捷(二):实现全栈敏捷
  3. Unity* 实体组件系统 (ECS)、C# 作业系统和突发编译器入门
  4. 【知识星球】LeNet5,AlexNet,VGG,MobileNet它们的前身都是什么,你知道吗?
  5. 从Powershell 入侵脚本学到的如何执行后台runspace~
  6. 非常实用的 Python 库,推一次火一次
  7. STM32基于SPI和AD7192的数据采集
  8. concurrentbag 删除指定元素_Python实现列表索引批量删除的5种方法_python
  9. P1024 一道naive的二分
  10. HTTPS客户端验证服务器端的过程
  11. API 接口 并发测试 Jmeter Postman
  12. java中运用数组排序_JAVA中运用数组的四种排序方法
  13. VS系列之【 产品密钥 – 所有版本】
  14. 苹果手机长截屏_智能长截屏工具,安卓/ios/电脑全平台都给你
  15. 宝峰uv5r怎么设置信道_宝峰5R说明书 及设置方法
  16. linux 关机流程 init exit,Linux开关机命令(shutdown,reboot,halt,init),haltinit
  17. Revit技巧 | 如何做出一个爆炸分析图?
  18. codeforces 545D. Queue
  19. C10k-problem
  20. 弹性盒之主轴与交叉轴的区分

热门文章

  1. Pycharm使用远程服务器运行代码
  2. 领域情报搜索实践:真实场景下的问答实施策略与风险分析
  3. bootstrap-table文档
  4. 20162317 2016-2017-2 《程序设计与数据结构》第8周学习总结
  5. ubuntu 安装yar和使用
  6. 设计模式——Template Method模板方法
  7. 如何理解在数据类型中元素不能修改?
  8. 移动短信回执怎么开通_才知道移动积分需要主动开通功能,才会消费产生积分,垃圾!!!...
  9. java官方 jax rs_jboss7 Java API for RESTful Web Services (JAX-RS) 官方文档
  10. 最长回文串_第78天——第78题(最长回文串 )