【MySQL】锁
- 0. 锁的考察点
- 1. 概述
- 1. 锁的分类
- 1.1 属性分类
- 1.2 粒度分类
- 2. 全局锁
- 2.1 全局锁操作
- 2.2.1 备份问题
- 3. 表级锁
- 3.1
- 附录
0. 锁的考察点
1. 概述
锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。
1. 锁的分类
1.1 属性分类
InnoDB存储引擎实现了两种标准的行级锁:共享锁(S Lock)和排他锁(X Lock)。
共享锁(S Lock):允许事务读一行数据。
排他锁(X Lock):允许事务删除或更新一行数据。
1.2 粒度分类
按照锁的粒度来分,分为以下三类
- 全局锁:锁定数据库中的所有表。
- 表级锁:每次操作锁住整张表。
- 行级锁:每次操作,锁住对应的行数据。
2. 全局锁
全局锁就是对整个数据库实例加锁,加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将被阻塞。
其典型的使用场景是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性。
如果不上锁,边备份,业务还正常执行就会造成数据不一致的问题。
2.1 全局锁操作
mysql> flush tables with read lock; // 加全局锁
Query OK, 0 rows affected (0.01 sec)mysql> insert into migrations values(7,'1231231',1); // 插入数据的时候
ERROR 1223 (HY000): Can't execute the query because you have a conflicting read lockmysql> unlock tables; // 销毁全局锁
Query OK, 0 rows affected (0.00 sec)mysql> insert into migrations values(7,'1231231',1); // 可以正常插入了
Query OK, 1 row affected (0.01 sec)
备份数据库(newdb3)的数据
(base) ➜ ~ mysqldump -u root -p newdb3>/Users/fanzhen/Downloads/newdb3.sql
Enter password:
2.2.1 备份问题
全局锁特点
数据库中加全局锁,是一个比较重的操作,存在以下问题:
-
如果在主库上备份,那么在备份期间都不能执行更新,业务基本上就得停摆。
-
如果在从库上备份,那么在备份期间从库不能执行主库同步过来的二进制日志(binlog),会导致主从延迟。
在InnoDB引擎中,我们可以在备份时加上参数-single-transaction
参数来完成不加锁的一致性数据备份。
3. 表级锁
表级锁,每次操作锁住整张表。锁定粒度大,发生锁冲突的概率最高,并发度最低。应用在MyISAM、InnoDB、BDB等存储引擎中。
对于表级锁,主要分为以下三类:
- 表锁
- 元数据锁(meta data lock, MDL)
- 意向锁
3.1
附录
- 徐庶MySQL锁 https://blog.csdn.net/bjjx123456/article/details/136180761
- 黑马讲解MySQL锁部分