MySQL里的锁有哪些

MySQL 的锁机制是实现并发控制的核心,不同层级的锁适用于不同场景,以下是对其锁类型的系统分类及详细说明:

一、按锁粒度划分

1. 全局锁(Global Lock)
  • 用途:锁定整个数据库实例,用于全库备份。

  • 命令:

    FLUSH TABLES WITH READ LOCK;  -- 加全局读锁
    UNLOCK TABLES;                -- 释放锁
    
  • 影响:阻塞所有写操作及DDL操作,仅允许读操作。

2. 表级锁(Table-Level Lock)
  • 表锁(Table Lock)

    • MyISAM引擎使用,分为:

      • 表共享读锁(S锁):允许其他会话读,阻塞写。
      • 表独占写锁(X锁):阻塞其他会话的读写。
    • 命令:

      LOCK TABLES table_name READ;  -- 加读锁
      LOCK TABLES table_name WRITE; -- 加写锁
      UNLOCK TABLES;               -- 释放锁
      
  • 元数据锁(Metadata Lock, MDL)

    • 自动加锁:访问表时自动加MDL读锁,修改结构时加MDL写锁。
    • 问题:长事务可能导致DDL阻塞(如ALTER TABLE等待)。
  • 意向锁(Intention Locks)

    • 作用:快速判断表内是否有行级锁冲突,减少锁检查开销。
    • 类型:
      • 意向共享锁(IS):表明事务意图对某些行加S锁。
      • 意向排他锁(IX):表明事务意图对某些行加X锁。
3. 行级锁(Row-Level Lock)
  • InnoDB引擎支持,锁定索引记录,类型包括:
    • 记录锁(Record Lock):锁定索引中的某一行。
    • 间隙锁(Gap Lock):锁定索引记录之间的间隙,防止幻读。
    • 临键锁(Next-Key Lock):记录锁 + 间隙锁,锁定左开右闭区间。
    • 插入意向锁(Insert Intention Lock):插入前对间隙加锁,允许不同插入位置的并发。
  • 自增锁(AUTO-INC Lock)
    • 用途:确保自增列(AUTO_INCREMENT)值的唯一性。
    • 优化:MySQL 8.0引入轻量级锁(互斥量),减少性能影响。

二、按锁模式划分

1. 共享锁(Shared Lock, S锁)
  • 行为:允许其他事务加S锁,阻塞X锁。

  • 使用场景:

    SELECT ... LOCK IN SHARE MODE;  -- 显式加S锁
    
2. 排他锁(Exclusive Lock, X锁)
  • 行为:阻塞其他事务的S锁和X锁。

  • 使用场景:

    SELECT ... FOR UPDATE;  -- 显式加X锁
    

三、按锁策略划分

1. 悲观锁(Pessimistic Locking)
  • 假设:认为并发冲突频繁,提前加锁。
  • 实现:通过SELECT ... FOR UPDATE显式加锁。
2. 乐观锁(Optimistic Locking)
  • 假设:认为冲突较少,通过版本号或时间戳控制。

  • 实现:

    UPDATE table SET column = new_value, version = version + 1 
    WHERE id = 1 AND version = old_version;
    

四、锁的兼容性与冲突

已存在的锁IS锁(新请求)IX锁(新请求)S锁(新请求)X锁(新请求)
IS锁
IX锁
S锁
X锁

五、不同隔离级别的锁策略

隔离级别锁机制
READ UNCOMMITTED不加锁(通过快照读),可能脏读。
READ COMMITTED行级锁(记录锁),无间隙锁,允许幻读。
REPEATABLE READ临键锁(Next-Key Lock)防止幻读,默认隔离级别。
SERIALIZABLE所有读操作隐式加共享锁,完全串行化。

六、锁的监控与诊断

1. 查看锁信息
SHOW ENGINE INNODB STATUS;          -- 查看Inno引擎状态(含锁信息)
SELECT * FROM information_schema.INNODB_LOCKS;   -- 当前持有的锁
SELECT * FROM information_schema.INNODB_LOCK_WAITS; -- 锁等待关系
2. 常见问题
  • 死锁:事务相互等待锁释放,InnoDB自动检测并回滚代价较小的事务。
  • 锁等待超时:由参数innodb_lock_wait_timeout控制(默认50秒)。

七、示例场景

场景1:防止超卖(临键锁)
-- 事务1:扣减库存
BEGIN;
SELECT stock FROM products WHERE id = 1 FOR UPDATE; -- 加X锁
UPDATE products SET stock = stock - 1 WHERE id = 1;
COMMIT;
  • 作用:临键锁防止其他事务插入新记录,确保库存准确。
场景2:批量插入(间隙锁)
-- 事务1:查询范围数据
BEGIN;
SELECT * FROM orders WHERE amount > 100 FOR UPDATE; -- 对间隙加锁
  • 作用:阻止其他事务在amount > 100范围内插入新数据。

总结

MySQL通过多粒度锁(全局锁、表锁、行锁)和多种锁模式(S/X锁、意向锁)实现高效的并发控制。合理选择事务隔离级别和锁策略(如临键锁防幻读、乐观锁降级冲突)是优化性能的关键。监控工具和诊断命令可帮助快速定位锁争用问题。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring WebFlux 教程

Spring WebFlux 教程 Spring WebFlux 是 Spring Framework 5 引入的一种新的响应式编程框架,旨在处理高并发、高性能和实时数据流应用。与传统基于线程阻塞的 Spring MVC 不同,WebFlux 采用了非阻塞、事件驱动的编程模型,能够更加高效地利用…

SCI英文论文Accepted后的第一步——Rights and Access

SCI英文论文Accepted后的第一步——Rights and Access 目录 SCI英文论文Accepted后的第一步——Rights and AccessBased on information provided the embargo period/end date is 24 months. 因为选择闭源**Rights and Access(版权与访问权限)**环节是关键第一步,具体操作流…

Qt文件管理系统

引言 今天我将使用model/view模型视图框架来完成一个简单的Qt文件管理系统,主要使用到了QTreeView、QTabelView视图和QFileSystemModel文件系统模型。 界面设计 使用Qt创建项目并勾选创建ui文件,打开ui文件,使用Tree View、Table View、St…

《可爱风格 2048 游戏项目:HTML 实现全解析》

一、引言 在如今的数字化时代,小游戏以其简单易上手、趣味性强的特点深受大家喜爱。2048 游戏作为一款经典的数字合并游戏,拥有庞大的玩家群体。本文将详细介绍一个用单文件 HTML 实现的可爱风格 2048 游戏项目,它不仅具备传统 2048 游戏的基…

CSS3:深度解析与实战应用

CSS3:深度解析与实战应用详解 1. 选择器增强2. 盒模型扩展3. 渐变和背景4. 转换和动画总结 CSS3 是 CSS(层叠样式表)的最新版本,它引入了许多新的特性和功能,使得网页的样式设计更加灵活、丰富和具有动态效果。在本文中…

C语言 —— 此去经年梦浪荡魂音 - 深入理解指针(卷四)

目录 1. 回调函数 2. qsort函数 2.1 使用qsort函数排序整型数据 2.2 使用qsort排序结构数据 2.3 使用冒泡排序模拟实现qsort函数 1. 回调函数 回调函数其实就是一个通过函数指针调用的函数,如果你把函数的指针作为参数传递给另一个函数,当这个指针被…

Shiro框架漏洞攻略

漏洞原理:服务端在接收到⼀个Cookie时,会按照如下步骤进⾏解析处理:1.检索RememberMe Cookie的值 2.进⾏Base64解码 3.进⾏AES解码 4.进⾏反序列化操作 在第4步中的调⽤反序列化时未进⾏任何过滤,进⽽可以导致出发远程代码执⾏漏…

Ceph集群2025(Squid版)导出高可用NFS集群(下集 )

本次主要对接K8S和传统的一样而已,比较简单,不再过多讲解 官网 https://github.com/kubernetes-csi/csi-driver-nfs/tree/master/chartshelm repo add csi-driver-nfs https://raw.githubusercontent.com/kubernetes-csi/csi-driver-nfs/master/charts helm pull c…

洛谷题单入门4-P5729 【深基5.例7】工艺品制作-python

输入格式 第一行三个正整数 w,x,h。 第二行一个正整数 q。 接下来 q 行,每行六个整数 输出格式 输出一个整数表示答案。 三维数组直接标记 class Solution:staticmethoddef oi_input():"""从标准输入读取数据"""w, x, h map(…

亚马逊云科技全面托管DeepSeek-R1模型现已上线

文章目录 亚马逊云科技全面托管DeepSeek-R1模型现已上线在Amazon Bedrock中开始使用DeepSeek-R1模型DeepSeek-R1现已可用 亚马逊云科技全面托管DeepSeek-R1模型现已上线 亚马逊云科技提供众多免费云产品,可以访问:亚马逊云科技 截至1月30日,D…

IO模型种类

文章目录 同步阻塞 I/O(Blocking I/O,BIO)同步非阻塞 I/O(Non-blocking I/O,NIO)I/O 多路复用(I/O Multiplexing)信号驱动 I/O(Signal-driven I/O)异步 I/O&a…

C语言入门教程100讲(40)文件定位

文章目录 1. 什么是文件定位?2. 文件指针3. 文件定位函数3.1 `fseek` 函数3.2 `ftell` 函数3.3 `rewind` 函数4. 示例代码代码解析:输出结果:5. 常见问题问题 1:`fseek` 的 `offset` 参数可以为负数吗?问题 2:如何判断文件定位是否成功?问题 3:`rewind` 和 `fseek(file…

el-table折叠懒加载支持排序

el-table折叠懒加载支持排序 因为el-table懒加载的子节点是通过缓存实现的,如果想在展开的情况下直接刷新对应子节点数据,要操作el-table组件自身数据,否则不会更新 以排序功能为例 maps: new Map() //用于存储子节点懒加载的数据// 加载子…

Off-Road-Freespace-Detection配置pytorch2.0.0

一、概述 在github上进行开源代码搜索,发现了Off-Road-Freespace-Detection(链接如下所示)。这是对越野环境可通行区域的检测,在经过测试之后,发现对自己有益。 GitHub - chaytonmin/Off-Road-Freespace-Detection: O…

ChatGPT降低论文AIGC重复率的提示词合集(高效降重方法)

💡 问题:写完毕业论文后,查AIGC率过高,手动降重后仍然很高,该怎么办? 📌 解决方案: 1️⃣ 先查AIGC率(找出AI生成的部分) 2️⃣ 用ChatGPT优化(使…

【Spring 新特性全解析】

Spring 新特性全解析 引言 在当今 Java 企业级开发领域,Spring 框架无疑是中流砥柱般的存在。它以其强大的功能、高度的可扩展性和便捷的开发体验,赢得了广大开发者的青睐。随着技术的不断演进,Spring 也在持续更新迭代,带来了一…

System.arraycopy 在音视频处理中的应用

在音视频开发领域,我们经常需要处理大量的数据,例如音频 PCM 数据的传输、视频帧的缓存等。在这些场景下,数据的复制与传输往往直接影响到应用的性能。Java 提供的 System.arraycopy 方法,在音视频处理代码中出现频率非常高。本文…

fastapi+angular评论和回复

说明:fastapiangular评论和回复 效果图: step1:sql show databases; DROP TABLE users; SHOW CREATE TABLE db_school.users; show tables; use db_school; SELECT * FROM db_school.jewelry_categories; CREATE DATABASE db_school; select *from users -- 用户…

C++11QT复习 (三)

文章目录 [toc]Day5-2 文件IO(2025.03.24)1. 缓冲区与刷新1.1 常见的缓冲刷新方式 2. 文件读写操作2.1 读取文件2.2 写入文件2.3 追加模式写入2.3 完整代码 3. 文件定位操作4. 字符串IO5. 配置文件解析示例6. 完整代码7. 二进制文件操作总结 Day5-2 文件…

Redis Sentinel 详解

Redis Sentinel 详解 1. 什么是 Redis Sentinel?有什么用? Redis Sentinel(哨兵) 是 Redis 官方提供的高可用性解决方案,主要用于监控、通知和自动故障转移。当 Redis 主节点(master)发生故障…