MySQL InnoDB 引擎的多版本并发控制(MVCC,Multi-Version Concurrency Control)是一种实现数据库并发控制的方法,能够在保证高并发性的同时提高性能。MVCC 通过维护数据的多个版本,使得读操作不会阻塞写操作,从而提高系统的整体效率。以下是对 InnoDB MVCC 的详细介绍:
MVCC 基本原理
MVCC 通过保存数据的多个版本来实现并发控制,每个事务在读取数据时,都会看到一个一致性视图,而不是被其他事务修改中的数据。InnoDB 通过以下几种方式实现 MVCC:
-
行版本控制:每一行记录在其隐含列中存储两个额外的版本号(隐藏列):
- DB_TRX_ID:最近修改该行的事务ID。
- DB_ROLL_PTR:指向回滚段的指针,用于存储旧版本的数据。
-
快照读(Snapshot Read):大多数 SELECT 语句默认使用快照读,读取的是事务开始时的数据库状态,而不是其他事务修改后的数据。这种读取方式不会加锁。
-
当前读(Current Read):用于需要读取最新数据并加锁的操作,如
SELECT ... FOR UPDATE
和SELECT ... LOCK IN SHARE MODE
。当前读会加锁,防止其他事务修改数据。
MVCC 工作机制
MVCC 通过以下机制实现数据的一致性视图:
-
一致性视图(Consistent View):
- 当事务启动时,会创建一个一致性视图,记录当前活动事务的快照。
- 在读取数据时,事务只会看到那些在快照创建之前提交的修改。