我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL的锁机制以及表的生命周期

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL的锁机制以及表的生命周期

这篇文章主要讲解了“MySQL的锁机制以及表的生命周期”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的锁机制以及表的生命周期”吧!

  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实例,只能使用一个特殊的占位符(甚至表可能不存在)。

感谢各位的阅读,以上就是“MySQL的锁机制以及表的生命周期”的内容了,经过本文的学习后,相信大家对MySQL的锁机制以及表的生命周期这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL的锁机制以及表的生命周期

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JVM类加载机制及生命周期的详细介绍

这篇文章主要讲解了“JVM类加载机制及生命周期的详细介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JVM类加载机制及生命周期的详细介绍”吧!一.目标:1.什么是类的加载?2.类的生命周期
2023-06-02

Golang函数的生命周期控制

go 语言函数的生命周期包括:声明阶段、调用阶段和返回阶段。实战案例:简单函数:在声明阶段定义,在调用阶段通过函数名调用,在返回阶段返回结果。defer 函数:在返回阶段执行指定代码,用于释放资源或善后操作。闭包:可以访问其定义作用域外部变
Golang函数的生命周期控制
2024-04-18

maven的生命周期及常用命令介绍

maven简介及优势 maven是一个项目构建和管理的工具,提供了帮助管理 构建、文档、报告、依赖、scms、发布、分发的方法。可以方便的编译代码、进行依赖管理、管理二进制库等等。maven的好处在于可以将项目过程规范化、自动化、高
2023-05-30

如何控制 Golang 协程的生命周期?

控制 go 协程的生命周期可以通过以下方式:创建协程:使用 go 关键字启动新任务。终止协程:等待所有协程完成,使用 sync.waitgroup。使用通道关闭信号。使用上下文 context.context。如何控制 Go 协程的生命周期
如何控制 Golang 协程的生命周期?
2024-05-21

vue的混入可以使用生命周期吗

vue的混入可以使用生命周期。mixins(混入)中的生命周期会与引入mixins的组件的生命周期整合在一起调用,而且mixins中的生命周期函数会比引入mixins的组件调用的快。需要注意,多个mixins的生命周期会融合到一起运行,但是同名属性、同名方法无法融合,可能会导致冲突或覆盖。
2023-05-14

详解WPF中的APP生命周期以及全局异常捕获

这篇文章主要为大家详细介绍了WPF中的APP生命周期以及全局异常捕获的相关资料,文中的示例代码讲解详细,对我们学习WPF有一点的帮助,需要的可以了解一下
2023-03-02

vue的混入可不可以使用生命周期

这篇文章主要介绍“vue的混入可不可以使用生命周期”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue的混入可不可以使用生命周期”文章能帮助大家解决问题。vue的混入可以使用生命周期。mixins(
2023-07-04

Java Spring中Bean的作用域及生命周期

这篇文章主要介绍了Java Spring中Bean的作用域及生命周期,Bean的作用域默认是单例模式的,也就是说所有⼈的使⽤的都是同⼀个对象,更多相关内容需要的朋友可以参考一下
2022-11-13

MySQL的锁机制之全局锁和表锁的实现

前言对mysql锁的总结学习,本文将围绕,加锁的概念,加锁的应用场景和优化,以php及不加锁会导致的问题这些方向进行总结学习。mysql的全局锁和表锁是本文的重编程点一、全局锁全局锁的介绍以及使用全局锁就是对整个数据库实例进行加锁。
2023-01-15

编程热搜

目录