【学习】封锁协议

技术背景(数据库/并发控制)

"封锁协议"是数据库管理系统(DBMS) 中实现**并发控制(Concurrency Control)**的核心机制之一,主要用于解决以下问题:

✅ 目标:

  1. 保证事务隔离性(Isolation)
  2. 避免并发操作导致的数据不一致
    • 如:丢失更新、脏读、不可重复读、幻读等
  3. 协调多个事务同时访问同一数据资源时的行为

🔐 常见封锁协议类型

虽然图片只写了"封锁协议",但在实际应用中,它通常指以下几种经典协议:

表格

协议名称 描述 特点
一级封锁协议 事务T在修改数据R前必须先对其加X锁,直到事务结束才释放。 防止"丢失更新",但允许脏读、不可重复读。
二级封锁协议 在一级基础上,要求读数据前加S锁,读完即可释放。 防止"丢失更新"+"脏读",但仍允许"不可重复读"。
三级封锁协议 在二级基础上,要求S锁必须持有到事务结束。 防止"丢失更新"+"脏读"+"不可重复读",即达到可重复读隔离级别。
两段锁协议(2PL, Two-Phase Locking) 所有锁必须在解锁前申请完毕;一旦开始解锁,就不能再申请新锁。 保证串行化调度,是实现最高隔离性的基础协议。

️ 注意:"封锁协议"有时也泛指这些协议的统称,具体语境下可能特指某一种。


🧩 应用场景举例

假设两个事务 T1 和 T2 同时操作账户余额:

sql 复制代码
-- T1: 转账 100 元从 A 到 B
BEGIN;
UPDATE accounts SET balance = balance - 100 WHERE id = 'A';  -- 需要 X 锁
UPDATE accounts SET balance = balance + 100 WHERE id = 'B';  -- 需要 X 锁
COMMIT;

-- T2: 查询 A 的余额
BEGIN;
SELECT balance FROM accounts WHERE id = 'A';  -- 需要 S 锁
COMMIT;

如果没有封锁协议,T2 可能在 T1 修改中途读取到中间状态(脏读),或者 T1 的修改被覆盖(丢失更新)。通过封锁协议,系统会自动加锁并排队执行,确保一致性。


📘 相关术语扩展

  • 共享锁(S Lock / Read Lock):允许多个事务同时读,但阻止写。
  • 排他锁(X Lock / Write Lock):只允许一个事务读写,其他事务均被阻塞。
  • 死锁(Deadlock):两个事务互相等待对方释放锁,需由系统检测并回滚其中一个。
  • 锁粒度:行锁、页锁、表锁 ------ 影响并发性能与开销。

✅ 总结

项目 内容
图片文字 封锁协议
所属领域 数据库系统 / 并发控制
核心作用 规范事务如何加锁/解锁,保障数据一致性和隔离性
典型协议 一级/二级/三级封锁协议、两段锁协议(2PL)
现实意义 是高并发系统中避免数据错乱的关键机制

📌 一句话概括

"封锁协议"是数据库用来管住"谁什么时候能改数据"的交通规则,没有它,多线程/多用户环境下数据就会乱成一锅粥。




相关推荐
Dream of maid42 分钟前
Python12(网络编程)
开发语言·网络·php
minji...2 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
运维行者_3 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
dashizhi20154 小时前
共享文件禁止拖动本地磁盘、共享文件禁止另存为、禁止打印共享文件、禁止复制共享文件的方法
运维·服务器·网络·安全·电脑
网教盟人才服务平台4 小时前
AI 全面重塑网络攻防生态,智能安全进入深度对抗时代
网络·人工智能·安全
炽烈小老头4 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
阿杰学AI5 小时前
AI核心知识115—大语言模型之 自监督学习(简洁且通俗易懂版)
人工智能·学习·ai·语言模型·aigc·监督学习·自监督学习
九英里路6 小时前
OS学习之路——动静态库制作与原理
linux·学习·操作系统·unix·进程·编译·动静态库
red_redemption6 小时前
自由学习记录(160)
学习
南無忘码至尊6 小时前
Unity学习90天-第2天-认识Unity生命周期函数并用 Update 控制物体移动,FixedUpdate 控制物理
学习·unity·游戏引擎