MySQL数据库(八)锁
一 概述
介绍
- 锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU,RAM,I/O)的争用以外,数据也是一种供许多用户共享的资源。
- 如何保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。
分类
- 全局锁:锁定数据库中的所有表。
- 表级锁:每次操作锁住整张表。
- 行级锁:每次操作锁住对应的行数据。
二 全局锁
1 介绍
- 全局锁就是对整个数据库实例加锁,加锁后整个实例就处于只读状态,后续的DML,DDL,以及更新操作的事务都将被阻塞。
- 其典型的使用场景是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性。
全局锁过程:
锁->备份->解锁
- flush tables with read lock;
- mysqldump -u root -p 123456 数据库名>sql文件名.sql(最好打开一个新的终端)
- unlock tables;