事务王国生存指南:隔离级别与锁实现的降维打击

一、ACID 实现原理

  1. 原子性(Atomicity)

    • 通过 undo log 实现:事务回滚时,逆向执行 undo log 中的操作。
    • 若事务失败,数据库会撤销所有未提交的修改。
  2. 一致性(Consistency)

    • 由应用层和数据库约束(如唯一索引、外键)共同保证。
    • 事务执行前后数据库必须满足所有预定义的业务规则。
  3. 隔离性(Isolation)

    • 通过锁机制或 MVCC(多版本并发控制)实现。
    • 不同隔离级别对应不同锁策略(如 READ COMMITTED 使用行级锁)。
  4. 持久性(Durability)

    • 依赖 redo log:事务提交时,修改先写入 redo log,再异步刷盘。
    • 崩溃恢复时通过 redo log 重放未持久化的操作。

二、隔离级别与问题

隔离级别 脏读 不可重复读 幻读 实现方式
READ UNCOMMITTED ✔️ ✔️ ✔️ 无锁
READ COMMITTED ✖️ ✔️ ✔️ 行级锁 + MVCC
REPEATABLE READ ✖️ ✖️ ✔️ MVCC + 间隙锁(如 MySQL)
SERIALIZABLE ✖️ ✖️ ✖️ 表级锁或严格串行化调度

三、MVCC 核心机制

  1. 版本链

    • 每行数据包含隐藏字段:DB_TRX_ID(事务ID)、DB_ROLL_PTR(回滚指针)。
    • 通过 undo log 构建历史版本链。
  2. ReadView

    • 事务启动时生成活跃事务列表,用于判断数据可见性。
    • 可见性规则
      • DB_TRX_ID 小于最小活跃事务ID → 可见
      • DB_TRX_ID 在活跃事务列表中 → 不可见
      • DB_TRX_ID 大于最大事务ID → 不可见
  3. 隔离级别差异

    • READ COMMITTED:每次查询生成新 ReadView
    • REPEATABLE READ:事务首次查询时生成 ReadView

四、悲观锁 vs 乐观锁

特性 悲观锁 乐观锁
实现方式 数据库锁(如 SELECT ... FOR UPDATE 版本号/时间戳 + CAS 机制
适用场景 高并发写冲突 低冲突场景
性能影响 锁竞争可能引发阻塞 无锁,但需处理重试逻辑

实现示例

  1. 悲观锁(MySQL)

    sql 复制代码
    BEGIN;
    SELECT * FROM table WHERE id=1 FOR UPDATE; -- 加行锁
    UPDATE table SET value=100 WHERE id=1;
    COMMIT;
  2. 乐观锁(Java)

    java 复制代码
    // 更新时检查版本号
    UPDATE table SET value=100, version=version+1 
    WHERE id=1 AND version=old_version;
    // 若影响行数为0,则重试或抛异常

五、关键设计权衡

  1. 隔离级别选择REPEATABLE READ 平衡了性能与一致性(如 MySQL 默认级别)。
  2. 锁粒度 :行级锁(InnoDB)比表级锁并发度高,但管理成本更高。
  3. MVCC 优势:读操作不阻塞写,提升并发性能。

实际选型需结合业务场景(如高频更新 vs 低频冲突)和数据库特性(如 MySQL 的间隙锁)。

相关推荐
踏浪无痕17 小时前
AI 时代架构师如何有效成长?
人工智能·后端·架构
程序员小假17 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
资生算法程序员_畅想家_剑魔17 小时前
Kotlin常见技术分享-02-相对于Java 的核心优势-协程
java·开发语言·kotlin
ProgramHan17 小时前
Spring Boot 3.2 新特性:虚拟线程的落地实践
java·jvm·spring boot
辞砚技术录18 小时前
MySQL面试题——联合索引
数据库·面试
nbsaas-boot18 小时前
Go vs Java 的三阶段切换路线图
java·开发语言·golang
小L~~~18 小时前
绿盟校招C++研发工程师一面复盘
c++·面试
毕设源码-钟学长18 小时前
【开题答辩全过程】以 基于Java的慕课点评网站为例,包含答辩的问题和答案
java·开发语言
武子康18 小时前
大数据-209 深度理解逻辑回归(Logistic Regression)与梯度下降优化算法
大数据·后端·机器学习
小北方城市网18 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存