mysql并发书籍_《高性能MySQL》读书笔记之 MySQL锁、事务、多版本并发控制的基础知识...

本文详细介绍了MySQL的并发控制机制,包括读写锁、锁粒度的概念,以及表锁和行级锁的区别。接着,讨论了事务的ACID属性和四种隔离级别,特别强调了可重复读级别下的幻读问题。此外,还深入探讨了InnoDB存储引擎中的死锁处理策略。最后,重点讲解了多版本并发控制(MVCC)的工作原理,如何在不同隔离级别下保证一致性。
摘要由CSDN通过智能技术生成

1.2 并发控制

1.2.1读写锁

在处理并发读或写时,通过实现一个由两种类型的锁组成的锁系统来解决问题。这两种类型的锁通常被称为 共享锁(shared lock) 和 排它锁(exclusive lock),也叫读锁(read lock)和写锁(write lock)。

读锁是共享的,或者说是不互相阻塞的。多个客户端可以在同一时刻读取同一个资源,而互不干扰。写锁则是排他的,也就是说一个写锁会阻塞其他写锁和读锁。

1.2.2锁粒度

为了提高共享资源的并发性,尽量只锁定需要修改的部分数据,而不是所有数据。

表锁(table lock)

表锁是MySQL中最基本的锁策略,并且是开销最小的策略。进行写操作(插入、删除、更新等)先需要获得写锁,这会阻塞其他用户对该表的所有读写操作。读锁之间是不相互阻塞的。写锁有比读锁更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面(写锁可以插入到锁队列的前面,反之读锁则不能插入到写锁的前面)。

ALTER TABLE之类的语句会使用表锁,并且会忽略存储引擎的锁机制。

行级锁(row lock)

行级锁可以最大限度的支持并发处理,但同时也到来了最大的锁开销。MySQL的InnoDB和XtraDB等存储引擎实现了行级锁。行级锁只在存储引擎层面实现,并且服务器层完全不了解存储引擎中的锁实现。

1.3事务

事务就是一组原子性的SQL查询,这组查询要么全部执行成功,要么全部执行失败。

事务的ACID概念:

原子性(atomicity):一个事务必需被视为一个不可分割的最小工作单元。

一致性(consistency):

隔离性(i

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值