MySql数据库锁处理

  • 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;

查看死锁日志可以知道死锁成因,死锁发生的位置,以及数据库做出的处理
MySql数据库锁处理_第1张图片

  • 查看锁等待时间 (默认50s)
show variables like 'innodb_lock_wait_timeout'; 
  • 死锁检测开启状态
show variables like 'innodb_deadlock_detect';

数据库模拟锁

利用 BEGINCOMMIT 模拟一个事务的生命周期,不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;

你可能感兴趣的