1.mysql中并发和隔离控制机制 meta-data元数据锁:在table cache缓存里实现的,为ddl(data definition language)提供隔离操作。一种特别的meta-data元数据类型,叫name lock。(sql层) 表级table-level数据锁(sql层) 存储引擎特有机制 -- row locks行锁,page
1.mysql中并发和隔离控制机制meta-data元数据锁:在table cache缓存里实现的,为ddl(data definition language)提供隔离操作。一种特别的meta-data元数据类型,叫name lock。(sql层)
表级table-level数据锁(sql层)
存储引擎特有机制 -- row locks行锁,page locks页锁,table locks表级,versioning版本(在引擎中实现)
全局读锁 -- flush tables with read lock(sql层)
2.在语句执行中表的生命周期
dml(data manipulation language)例子:
计算语句使用到的所有表
在每个表:打开open表 -- 从table cache缓存里得到table对象,并在此表加上meta-data元数据锁
等待全局读锁后改变数据
在每个表:锁lock表 -- 在表加上table-level数据锁
执行语句:调用:handler::write_row()/read_rnd()/read_index(),等;隐式地调用引擎级engine-level锁机制
在每个表:释放表的数据锁
在每个表:释放表的ddl锁并把表放回table cache缓存里
ddl语句也是一样,没有典型的执行计划。
3.获取meta-data元数据锁
meta-data元数据锁的实现作为table对象的一个属性,table对象代表了table cache缓存。
meta-data元数据锁为如下任何一种:shared共享锁 -- 隐式地加锁,只通过标记table对象“被使用”;semi-exclusive半独享锁,也叫name lock,rename操作会在源表和目标加上此锁;exclusive独享,也叫exclusive name lock,create table ... select操作会在目标表上加上此锁,如果没有的话。
4.表高速缓存(table cache)
是一个hash变量,叫open_cache
table对象是hash元素
以hash的操作被lock_open mutex互斥量保护
内部结构(the table cache: internal structure)
在缓存里,每个物理表可能被多个table实例表示
相同表的所有table实例,通过相连的列(a linked list)连接着
每个table实例有一个table cache缓存版本的复制 -- table实例保存的版本不会和当前table cache缓存版本一致,而是保存旧的和从缓存删除的
被某些语句使用的table实例被会标记为对其它的语句来说是无效的 -- 这就是meta-data元数据锁的本质
在缓存中的table实例通常地有一个有效的句柄实例连接着它
内部运算(the table cache: operations)
主要的代码在:sql/sql_base.cc,sql/lock.cc,sql/table.h,sql/sql_table.cc
主要的方法:open_table(),close_thread_tables(),close_cached_table(),lock_table_names()
事实上,一个概念/对象组合不仅用于缓存或锁定:lock_open mutex互斥量也用到其它的操作,如:使磁盘上和处理中的表创建的原子性
典型的操作,来自隔离等级pov的重要(注:isolation pov没研究出是什么意思):语句查询时,打开和关闭表 -- shared共享锁;强制和等待直到表的所有实例被关闭 -- exclusive独享(但不完全);name lock -- 特殊地情况,当手上没有table实例,只能使用一个特殊的占位符(甚至表可能不存在)。