- MySQL有三种锁的级别:页级、表级、行级
- 两种基本的锁类型
- 排它锁(Exclusive Locks,即X锁)
当数据对象被加上排它锁时,其他的事务不能对它读取和修改。 - 共享锁(Share Locks,即S锁)。
加了共享锁的数据对象可以被其他事务读取,但不能修改。
数据库操作
show full PROCESSLIST
select * from information_schema.innodb_trx;
- KILL
trx_mysql_thread_id 杀死线程 若存在死锁 杀死死锁线程
KILL 8437;
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
SHOW ENGINE INNODB STATUS;
查看死锁日志可以知道死锁成因,死锁发生的位置,以及数据库做出的处理
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 即不提交, 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;
|