概念
锁是计算机协调多个进程或县城并发访问某一资源的机制
全局锁
概念特点:
锁定库中的所有表,加锁后整个实例(表)就处于只读状态,后续的DML、DDL语句,已经更新操作的事务提交语句都会被阻塞
使用场景:全库的逻辑备份,对所有表进行锁定,获取一致性视图,保证数据完整性
加锁语句:flush tables with read lock;
备份语句:mysqldump -uroot -p密码 itcast(哪个数据库)> itcast.sql(哪个sql文件) 不在mysql命令行执行
解锁语句:unlock tables;
缺陷:如果在主库上备份,那么备份期间不能执行更新,业务基本上就得停摆
如果虚拟机是主从结构,而且做了读写分离,这时候写入操作时不会阻塞,会从从库进行备份,但备份期间
从库是不能执行从主库同步过来的二进制日志,会导致主从延迟
解决方案:在备份时加上参数 --single-transaction 参数来完成不加锁的一致性数据备份
语法:mysqldump --single-transaction -uroot -p密码 库名> sql文件
表级锁
概念特点
每次操作锁住整张表
锁定粒度大,发生锁冲突的概率最高,并发度最低,应用在MyISAM,InnoDB,BDB等存储引擎中
分类:
全局锁又分为表锁、元数据锁、意向锁,表锁又分为表共享读锁、表独占写锁
表锁:
加锁:lock tables 表名... read/write
释放锁:unlock tables / 客户端断开连接
表共享读锁
读锁不会阻塞其他客户端的读,但是会阻塞写
当前客户端只可读,不可写
表独占写锁
写锁既会阻塞其他客户端的读,又会阻塞其他客户端的写
当前客户端可读可写
元数据锁
元数据锁加锁过程是系统自动控制,无需显式使用,在访问一张表的时候会自动加上
主要用于维护表元数据的一致性,在表上有活动事务的时候,不允许对元数据进行写入操作
为了避免DML与DDL冲突,保证读写的正确性。
SQL5.5中引入了MDL,读锁兼容共享(inset、select、delete、update),写锁排他(alter)
意向锁
为了避免DML在执行时,加的行锁与表锁的冲突,在InnoDB引入了意向锁,使得表锁不用检查每行数据,是否加锁,使用意向锁来减少表锁的检查
执行过程:线程A开启事务执行update,会加上行锁,紧接着对表加上意向锁
线程B对表加表锁,首先会检查表的意向锁是否与表锁兼容,兼容直接加锁,不兼容就会阻塞,
阻塞到线程A提交事务释放行锁和意向锁。
意向共享锁(IS):由语句 select ... lock in share mode添加,与表共享锁(read)兼容,与表排它锁(write)互斥
意向排它锁(IX):由insert、update、delete、select ... for update添加,与表共享锁(read)和表排它锁(write)都互斥,意向锁之间不会互斥
查看意向锁、行锁加锁情况语句:
select
object_schema,object_name,index_name,
lock_type,lock_mode,lock_data
from performance_scheman.data-locks
行级锁
概念特点
每次操作锁住对应的行数据
锁定粒度最小,发生冲突概率最低,并发度最高,应用在InnoDB存储引擎中,通过索引上的索引项加锁实现
分类:
行级锁又分为行锁、间隙锁、临键锁,行锁又分共享锁、排它锁
行锁:
锁定单个记录的锁,防止其他事物对此进行update和delete,在RC、RR隔离级别下都支持
InnoDB使用 next-key锁进行搜索和索引扫描,防止幻读
1.针对唯一索引进行检索时,对已存在的记录进行等值匹配时,会自动优化为行锁
2.InnoDB的行锁是针对于索引加的锁,不通过索引条件检查数据,InnoDB将对表中的所有记录加锁,升级为表锁
查询锁情况语句:
select
object_schema,object_name,index_name,
lock_type,lock_mode,lock_data
from performance_scheman.data-locks
共享锁(S):允许一个事务去读一行,阻止其他事务获得相同数据集的排它锁
排它锁(X):允许获取排它锁的事务更新数据,阻止其他事务获得相同数据集的共享锁和排它锁(事务获取了某行数据的排它锁,其他事务就不能再获取这行数据的共享锁和排它锁)
间隙锁:
锁定索引记录间隙(不含该记录,如1 10,间隙=1~10不包含1和10),确保索引记录间隙不变,防止其他事物在这个间隙进行 insert,产生幻读。在RR隔离级别下支持
临键锁:
行锁和间隙锁的组合,同时锁住数据,并锁住数据前面的间隙Gap,在RR隔离级别下支持
间隙锁+临键锁:
1.索引上的等值查询(唯一索引),给不存在的记录加锁时,优化为间隙锁
2.索引上的等值查询(普通索引),向右遍历时最后一个值不满足查询需求时,next-key lock 退化为间隙锁
3.索引上的等值查询(唯一索引),--会访问到不满足条件的第一值为止
注意:间隙锁唯一目的是防止其他事务插入间隙,间隙锁可以共存,一个事务采用的间隙锁不会阻止另一个事务在同一间隙上采用间隙锁