一、简介
锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除了传统的计算资源(CPU、RAM、i/O)的挣用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素,从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。
二、分类
MySQL中的锁、按照锁的粒度分,分为以下三类
- 全局锁:锁定数据量的所有表
- 表级锁:每次操作锁住整张表
- 行级锁:每次操作锁住对应的行数据
三、全局锁
3.1 简介
全局锁就是对整个数据库实例枷锁,加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,以及更新操作的事物提交语句都会被阻塞,其典型的使用场景是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性。
3.2 添加全局锁语法
flush tables with read lock;
09-04 08:47