- MySQL有三种锁的级别:页级、表级、行级
- 两种基本的锁类型
- 排它锁(Exclusive Locks,即X锁)
当数据对象被加上排它锁时,其他的事务不能对它读取和修改。 - 共享锁(Share Locks,即S锁)。
加了共享锁的数据对象可以被其他事务读取,但不能修改。
- 排它锁(Exclusive Locks,即X锁)
数据库操作
- 显示哪些线程正在运行
show full PROCESSLIST
- 查询当前的事务
select * from information_schema.innodb_trx;
- KILL
trx_mysql_thread_id
杀死线程 若存在死锁 杀死死锁线程
KILL 8437;
- 查看当前锁定的事务
-- 5.7
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
-- 8.0
select * from performance_schema.data_locks;
- 查看当前等锁的事务
-- 5.7
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
-- 8.0
select * from performance_schema.data_lock_waits;
- 查看死锁日志
SHOW ENGINE INNODB STATUS;
查看死锁日志可以知道死锁成因,死锁发生的位置,以及数据库做出的处理
- 查看锁等待时间 (默认50s)
show variables like 'innodb_lock_wait_timeout';
- 死锁检测开启状态
show variables like 'innodb_deadlock_detect';
数据库模拟锁
利用 BEGIN
和COMMIT
模拟一个事务的生命周期,不COMMIT
即事务进行中
- 手动锁定一行数据
BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
-- COMMIT;
不commit
即不提交, FOR UPDATE
会加一个行级锁
- 模拟死锁
Deadlock
死锁一般会报错:Deadlock found when trying to get lock; try restarting transaction
死锁是指两个或两个以上事务在执行过程中因争抢锁资源而造成的互相等待的现象。
客户端1:
BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
SELECT * FROM biz_plank_sample WHERE bar_code = '12565452535658' FOR UPDATE;
COMMIT;
客户端2:
BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '12565452535658' FOR UPDATE;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
COMMIT;