Innodb 锁系列1

同步机制

Innodb实现了不依赖于平台的mutex,rwlock。

1. 全局变量

  对于mutex, rwlock,都有一个全局链表。

1. mutex全局链表:mutex_list

2. rwlock全局链表:rw_lock_list

  在create创建mutex 或者rwlock的时候,加入链表。

  在delete销毁mutex或者rwlock的时候,从链表中删除。

3. 全局等待数组:

  sync_primary_wait_array = sync_array_create(OS_THREAD_MAX_N,  SYNC_ARRAY_OS_MUTEX);

  srv_max_n_threads决定了数组的大小,即同时wait的线程数。

2. mutex

struct mutex_struct {
  os_event_t    event;
  volatile lock_word_t    lock_word;
  os_fast_mutex_t os_fast_mutex;
  UT_LIST_NODE_T(mutex_t)    list;

event:    wait,notify使用的条件变量,在pthread中等同于condition。
lock_word:  如果系统支持TAS指令,那么就直接使用tas指令
os_fast_mutex:如果系统部支持TAS,那么在linux环境下就是封装的pthread_mutex;
list:       innodb中的所有mutex都维持一个链表。

假设我们讨论的平台是x86-64位的linux系统。

mutex的相关函数:

  mutex_create_func: 创建mutex,condition

  mutex_own:判断是否是当前线程持有mutex

  mutex_enter:获取mutex,使用的是trylock方式,如果不能获取,则进入spin,仍然不能获取,则进入等待队列

  mutex_exit:释放mutex。

3. rw_lock:

struct rw_lock_struct {
volatile lint    lock_word;
                    /*!< Holds the state of the lock. */
volatile ulint    waiters;     /*!< 1: there are waiters */
os_event_t    event;          /*!< Used by sync0arr.c for thread queueing */
os_event_t    wait_ex_event;
mutex_t    mutex;
UT_LIST_NODE_T(rw_lock_t) list;

相关函数:

  rw_lock_create_func: 初始化lock_word   #define X_LOCK_DECR 0x00100000 即同时支持1,048,575 concurrent readers

  rw_lock_lock_word_decr: 每次获取share_lock,就递减lock _word.

  rw_lock_s_lock_spin

  rw_lock_x_lock_wait

注:

  整体上来看,在linux平台上,mutex,condition的实现仍然使用pthread包中的mutex,cond。 rwlock的实现不依赖于pthread_rwlock.

  然后,innodb代码上多次使用数组等结构,增加了mutex的持有和释放的开销。

  总的来说,解决了多平台的问题,但引入了部分开销。

Innodb 锁系列1

时间: 2024-08-04 22:19:52

Innodb 锁系列1的相关文章

Innodb 锁系列2 事务锁

上一篇介绍了Innodb的同步机制锁:Innodb锁系列1 这一篇介绍一下Innodb的事务锁,只所以称为事务锁,是因为Innodb为实现事务的ACID特性,而添加的表锁或者行级锁. 这一部分分两篇来介绍,先来介绍下事务锁相关的数据结构 事务锁数据结构 1. 锁模式 /* Basic lock modes */ enum lock_mode { LOCK_IS = 0, /* intention shared */ LOCK_IX, /* intention exclusive */ LOCK_

MySQL锁系列2 表锁

上一篇介绍了MySQL源码中保护内存结构或变量的锁,这里开始介绍下MySQL事务中的表锁. 注1: 在表锁的实现上面,使用[mutex+condition+queue]的结构实现并发,阻塞,唤醒的表锁功能. 注2: 本文进行的一些实验,重要的配置项: 1. autocommit=0 2. tx_isolation=read-commited 3. engine=innodb 1. MySQL加锁的顺序: 这里包括了一个sql在执行的过程中,包括commit,所添加和释放跟事务相关的锁以及加不同锁

MySQL锁系列3 MDL锁

MySQL为了保护数据字典元数据,使用了metadata lock,即MDL锁,保证在并发的情况下,结构变更的一致性. MDL锁的加锁模式和源码上的组织上和上一篇blog中MySQL表锁的实现方式一致,都采用了[mutex+condition+queue]来实现并发,阻塞,唤醒的控制. 下面就来看看MDL锁: 1. 重要的数据结构:    1. MDL_map mdl_map使用hash表,保存了MySQL所有的mdl_lock,全局共享,使用MDL_KEY作为key来表,key=[db_nam

【锁】Oracle锁系列

[锁]Oracle锁系列 1  BLOG文档结构图 2  前言部分 2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~: ① 锁的概念.分类.及其模拟 ② 查询锁的视图及视图之间的关联 ③ 锁的参数(DML_LOCKS.DDL_LOCK_TIMEOUT) ④ FOR UPDATE及FOR UPDATE OF系列 ⑤ 带ONLINE和不带ONLINE创建索引的锁情况(是否阻塞DML操作) ⑥ 包或存过不能编译的解决方法

innodb 锁分裂继承与迁移

innodb行锁简介 行锁类型 LOCK_S:共享锁 LOCK_X: 排他锁 GAP类型 LOCK_GAP:只锁间隙 LOCK_REC_NO_GAP:只锁记录 LOCK_ORDINARY: 锁记录和记录之前的间隙 LOCK_INSERT_INTENTION: 插入意向锁,用于insert时检查锁冲突 每个行锁由锁类型和GAP类型组成例如:LOCK_X|LOCK_ORDINARY 表示对记录和记录之前的间隙加排他锁LOCK_S|LOCK_GAP 表示只对记录前的间隙加共享锁 锁的兼容性:值得注意的

圣天诺HL硬锁系列

HL Basic 授权锁 圣天诺HL系列中功能最简单.最经济型的硬锁,适合于不需要许可模式和存储空间的软件商. HL Pro 授权锁 此款产品在HL Basic基础上提供了224字节存储空间.适合对功能模块较少的软件产品,进行高强度保护和许可授权. HL Max 标准型 授权锁 HL Max系列在性能上是HL Pro更高级的型号.它可以对拥有大量组件的软件产品提供可计量的许可模式.锁内提供6k存储空间. HL Max 微型 授权锁 外形最小巧的授权锁.不必担心接入电脑或设备后被剐蹭.尤为适合与笔

[转载] 数据库分析手记 —— InnoDB锁机制分析

作者:倪煜 InnoDB锁机制常常困扰大家,不同的条件下往往表现出不同的锁竞争,在实际工作中经常要分析各种锁超时.死锁的问题.本文通过不同条件下的实验,利用InnoDB系统给出的各种信息,分析了锁的工作机制.通过本文可以帮助大家了解InnoDB锁的基本原理,常见的冲突.死锁,以及对InnoDB事务日志信息的解读. 1. 索引基本原理 InnoDB主要使用行级锁(row lock),其行锁是通过在索引项上加锁而实现的,如果MySQL的执行计划没有用到索引,那么行锁也就无意义了,所以了解锁之前需要了

InnoDB锁机制分析

InnoDB锁机制常常困扰大家,不同的条件下往往表现出不同的锁竞争,在实际工作中经常要分析各种锁超时.死锁的问题.本文通过不同条件下的实验,利用InnoDB系统给出的各种信息,分析了锁的工作机制.通过本文可以帮助大家了解InnoDB锁的基本原理,常见的冲突.死锁,以及对InnoDB事务日志信息的解读. 1. 索引基本原理 InnoDB主要使用行级锁(row lock),其行锁是通过在索引项上加锁而实现的,如果MySQL的执行计划没有用到索引,那么行锁也就无意义了,所以了解锁之前需要了解一点索引原

mysql: 关于MySQL InnoDB锁行还是锁表?

baidu zone - 关于MYSQL Innodb 锁行还是锁表,深入讲解