⑩⑦【MySQL】锁:全局锁、表级锁、行级锁

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

在这里插入图片描述

MySQL锁

  • ⑩⑦【MySQL】锁:全局锁、表级锁、行级锁
    • 1. 锁
    • 2. 全局锁
    • 3. 表级锁
      • 🔒表锁
      • 🔒元数据锁
      • 🔒意向锁
    • 4. 行级锁
      • 🔒行锁
      • 🔒间隙锁 / 临键锁


⑩⑦【MySQL】锁:全局锁、表级锁、行级锁


1. 锁

  • 锁是什么?
  • 锁是计算机协调多个进程或线程并发访问某一资源的机制 。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性 是所有数据库必须解决的一个问题,锁冲突 也是影响数据库并发访问性能的一个重要因素。从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。

锁的分类

  • MySQL中的锁,按照锁的粒度分,可分为下述三类:
    • 全局锁:锁定数据库中所有的表。
    • 表级锁:每次操作锁住整张表。
    • 行级锁:每次操作锁住对应的行数据。



2. 全局锁

全局锁

  • 全局锁就是对整个数据库实例加锁加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将被阻塞。其典型的使用场景是:做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性

在这里插入图片描述



  • 🚀设置全局锁:

    • FLUSH TABLES WITH READ LOCK;
      

  • 🚀MySQL数据备份:

    • # MySQL数据库备份的 (命令行指令)
      mysqldump -uroot -p密码 备份数据库名>保存备份的文件名
      # 实例:
      # mysqldump -uroot -p123456 mydb>mydb.sql
      

  • 🚀解除全局锁:

    • UNLOCK TABLES;
      



3. 表级锁

表级锁

  • 表级锁,每次操作锁住整张表。锁定粒度大,发生锁冲突的概率最高,并发度最低 。应用在MyISAM、InnoDB、BDB等存储引擎中。


🔒表锁

表级锁分类

  • 表锁 :表共享读锁(read lock) / 表独享写锁(write lock)

    • -- 设置表锁
      -- 设置了读锁read lock,当前客户端和其他客户端都只能读不能写。
      -- 设置了写锁write lock,当前客户端对当前表可读可写,其他客户端不能读不能写。
      LOCK TABLES 表名1[,表名2,...] {READ | WRITE};
      
      -- 释放锁
      UNLOCK TABLES;
      
    • 读锁不会阻塞其他客户端的读操作,但会阻塞写操作。写锁即阻塞其他客户端的读操作又阻塞其他客户端的写操作



🔒元数据锁

  • 元数据锁(meta data lock,MDL)

    • ⚪MDL加锁过程是系统自动控制 ,无需显式使用,在访问一张表的时候会自动加上。MDL锁主要作用是维护表元数据的数据一致性 ,在表上有活动事务的时候,不可以对元数据进行写入操作。作用为了避免DML与DDL冲突,保证读写的正确性。

    • ⚪在MySQL5.5中引入了MDL,当对一张表进行增删改查的时候,加MDL读锁(共享) ;当对表结构进行变更操作的时候,加MDL写锁(排他)

    • 在这里插入图片描述

    • -- 查看元数据锁
      select object_type,object_schema,object_name,lock_type,lock_duration from
      performance_schema.metadata_locks ;
      



🔒意向锁

  • 意向锁

    • 为了避免DML语句在执行时,加的行锁与表锁的冲突,在InnoDB中引入了意向锁,使得表锁不用检查每行数据是否加锁,使用意向锁来减少表锁的检查。

    • 意向共享锁(IS) :与表锁共享锁(read)兼容,与表锁排它锁(write)互斥。

    • 意向排他锁(IX) :与表锁共享锁(read)及排它锁(write)都互斥。意向锁之间不会互斥。

    • -- 查看意向锁加锁情况
      select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from
      performance_schema.data_locks;
      
      -- 添加意向共享锁(IS)
      SELECT语句 LOCK IN SHARE MODE;
      
      -- 添加意向排他锁(IX)
      {INSERT语句 | UPDATE语句 | DELETE语句 | SELECT语句}
      FOR UPDATE;
      



4. 行级锁

行级锁

  • 行级锁,应用在InnoDB存储引擎中,每次操作锁住对应的行数据。锁定粒度最小,发生锁冲突的概率最低,并发度最高
  • InnoDB的数据是基于索引组织的,行锁是通过对索引上的索引项加锁来实现的,而不是对记录加的锁。对于行级锁,主要分为以下三类:
    • 行锁(Record Lock)
      • 锁定单个行记录的锁,防止其他事务对此行进行updatedelete操作。在RC、RR隔离级别下都支持。
    • 间隙锁(Gap Lock)
      • 锁定索引记录间隙(不含该记录),确保索引记录间隙不变,防止其他事务在这个间隙进行insert操作,产生幻读。在RR隔离级别下支持。
    • 临键锁(Next-Key Lock)
      • 行锁和间隙锁组合,同时锁住数据,并锁住数据前面的间隙Gap。在RR隔离级别下支持。



🔒行锁

  • InnoDB实现了以下两种类型的行锁:
    • 共享锁(S):允许一个事务去读一行,阻止其他事务获得相同数据集的排它锁。即共享锁间兼容,但与排他锁互斥。

    • 排他锁(X):允许获取排他锁的事务更新数据,阻止其他事务获得相同数据集的共享锁和排他锁。

    • 在这里插入图片描述

    • 在这里插入图片描述


行锁执行原理

默认情况下,InnoDBREPEATABLE READ事务隔离级别运行,InnoDB使用next-key锁进行搜索和索引扫描,以防止幻读。

    1. 针对唯一索引进行检索时,对已存在的记录进行等值匹配时 ,将会自动优化为行锁
    2. InnoDB的行锁是针对于索引加的锁,不通过索引条件检索数据,那么InnoDB将对表中的所有记录加锁 ,此时就会升级为表锁

  • 🚀查看 行锁/意向锁 加锁情况:

    • select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from
      performance_schema.data_locks;
      



🔒间隙锁 / 临键锁

间隙锁 / 临键锁 执行原理:

默认情况下,InnoDBREPEATABLE READ事务隔离级别运行,InnoDB使用next-key锁进行搜索和索引扫描,以防止幻读。

    1. 索引上的等值查询(唯一索引),给不存在的记录加锁时,优化为间隙锁
    2. 索引上的等值查询(普通索引),向右遍历时最后一个值不满足查询需求时,next-key lock退化为间隙锁
    3. 索引上的范围查询(唯一索引),会访问到不满足条件的第一个值为止。
  • 间隙锁唯一目的是防止其他事务插入间隙间隙锁可以共存 ,一个事务采用的间隙锁不会阻止另一个事务在同一间隙上采用间隙锁。




在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/171178.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

官宣!Sam Altman加入微软,OpenAI临时CEO曝光,回顾董事会‘’政变‘’始末

11月20日下午,微软首席执行官Satya Nadella在社交平台宣布,“微软仍然致力于与 OpenAI的合作伙伴关系。同时欢迎Sam Altman 和 Greg Brockman 及其团队加入微软,领导一个全新的AI研究团队”。 Sam第一时间对这个消息进行了确认。 此外&…

【机器学习】对比学习(contrastive learning)

对比学习是一种机器学习技术,算法学习区分相似和不相似的数据点。对比学习的目标是学习数据的表示,以捕捉不同数据点之间的基本结构和关系。 在对比学习中,算法被训练最大化相似数据点之间的相似度,并最小化不相似数据点之间的相似…

LOJ #10134. 「一本通 4.4 练习 1」Dis

分析 根据数据范围分析一下复杂度,Floyd和dj算法都必爆。 发现题目说的是树,还是边还是双向的(树本身就是无向的,连通无回路的无向图叫做无向树,简称树。如果题目说了树,那么默认边就是双向的&#xff09…

优思学院|现代质量管理实践与六西格玛方法论如何融合?

企业要解决质量问题必然需要涉及管理,然而,如果仅仅将六西格玛法视为一种质量管理方法,必定会导致六西格玛管理法的失败。六西格玛法是一种具有特定战略性的管理方法,它涉及到市场、顾客、产品、服务、流程、质量、价值链以及财务…

利用多核的Rust快速Merkle tree

1. 引言 利用多核的Rust快速Merkle tree,开源代码见: https://github.com/anoushk1234/fast-merkle-tree(Rust) 其具有如下属性: 可调整为任意高度构建root复杂度为O(n)提供了插入和获取叶子节点的方法获取某叶子节…

centos7 利用nc命令探测某个tcp端口是否在监听

脚本 # 安装nc yum install -y ncnc -vz 192.168.3.128 60001 if [ $? -eq 0 ]; thenecho "tcp succeed" elseecho "tcp failed" fi nc -vz 192.168.3.128 60001 探测192.168.3.128服务器上60001 tcp端口, -vz说明是探测TCP的 端口开启的情况 执行…

用不用Microsoft Defender是你的自由,但不用最好也得有替代品

Microsoft Defender是预装在Windows 11操作系统上的重要安全工具。安全套件已完全集成到操作系统中,以保护你的系统免受恶意软件的攻击,但并不是每个人都喜欢它。你是否更愿意安装另一种防病毒/反间谍软件,以将Microsoft Defender推向绝境&am…

ATA-304功率放大器的电子实验案例(案例合集)

ATA-304功率放大器凭借其优异的指标参数受到不少电子工程师的喜欢,其在电子实验中的应用也非常频繁,下面为大家整理出ATA-304功率放大器的应用案例合集,希望能对领域内各位工程师、研究人员有所帮助。 案例一:ATA-304功率放大器在…

并行与分布式 第4章 数据级并行:向量体系结构和GPU

文章目录 并行与分布式 第4章 数据级并行:向量体系结构和GPU4.1 什么叫数据级并行4.1.1 数据级并行与SPMD4.1.2数据级并行——传统器件的问题4.1.3 数据级并行——向量体系结构和GPU 4.2 向量体系结构4.2.1 向量以及计算方式4.2.2 向量体系结构4.2.3 向量运算的执行…

如何在公网环境下使用内网穿透工具实现用ipad pro进行代码开发

文章目录 前言1. 本地环境配置2. 内网穿透2.1 安装cpolar内网穿透(支持一键自动安装脚本)2.2 创建HTTP隧道 3. 测试远程访问4. 配置固定二级子域名4.1 保留二级子域名4.2 配置二级子域名 5. 测试使用固定二级子域名远程访问6. iPad通过软件远程vscode6.1 创建TCP隧道 7. ipad远…

解锁数据库运维秘籍:掌握AntDB-T动态共享内存,提升进程间通信效率

动态共享内存是AntDB数据库通信的重要手段,本文主要阐述AntDB-T数据库动态共享内存的实现原理、实现方式与使用方法。 AntDB-T数据库是一款企业级通用分布式关系型数据库,其数据库内核是基于进程模型实现的,因此进程间通信(IPC&am…

撸源代码破冰杀手锏(一):Spring Security系列

一: 禅悟人生,码砖破冰感悟 二: Spring Security安全阐述 忙着去耍帅,后期补充完整.................

腾讯云服务器标准型S5实例CPU性能如何?配置特性说明

腾讯云服务器CVM标准型S5实例具有稳定的计算性能,CVM 2核2G S5活动优惠价格280.8元一年自带1M带宽,15个月313.2元、2核4G配置748.2元15个月,CPU内存配置还可以选择4核8G、8核16G等配置,公网带宽可选1M、3M、5M或10M,腾…

日期格式转化成星期几部署到linux显示英文

异常收集 原因:解决办法仰天大笑出门去,我辈岂是蓬蒿人 传入一个时间获取这个时间对应的是星期几,在开发环境(window系统)中显示为星期几,部署到服务器(linux系统)中会显示英文的时间…

什么是单片机?聊聊它的历史

前言 1946年2月15日,第一台电子数字计算机 ENIAC问世,这标志着计算机时代的到来。 ENIAC 是电子管计算机,时钟频率虽然仅有 100 kHz,但能在1s 的时间内完成 5000 次加法运算。与现代的计算机相比,ENIAC有许多不足&am…

腾讯云标准型s5和s6有什么区别?CPU处理器有差异吗?

腾讯云服务器CVM标准型S5和S6有什么区别?都是标准型云服务器,标准型S5是次新一代云服务器规格,标准型S6是最新一代的云服务器,S6实例的CPU处理器主频性能要高于S5实例,同CPU内存配置下的标准型S6实例要比S5实例性能更好…

KyLin离线安装OceanBase

去OceanBase下载若干文件 1 首先安装ob-deploy-2.3.1-2.el7.x86_64.rpm rpm -ivh ob-deploy-2.3.1-2.el7.x86_64.rpm# 运行此命令的时候他会报错 RPM should not be used directly install RPM packages, use Alien instead! 这个需要用Alien去转换为deb的包,不…

Linux中,查看Tomcat版本、如何查看Tomcat版本

方法 在tomcat的bin目录下,执行version.sh命令即可 结果

Pytorch完整的模型训练套路

Pytorch完整的模型训练套路 文章目录 Pytorch完整的模型训练套路以CIFAR10为例实践 数据集加载步骤 使用适当的库加载数据集,例如torchvision、TensorFlow的tf.data等。 将数据集分为训练集和测试集,并进行必要的预处理,如归一化、数据增强等…

桌面运维。

Windows运行命令: color 01/02切换字符颜色cls 清屏ipconfig 设备的ip信息ipconfig /all 设备ip的所有信息 破解系统密码: 进PE系统,使用里面的工具破解 vmware workstation安装 网卡 网卡:ncpa.cpl window远程控制 mstsc …