栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MySql数据库锁处理

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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;

查看死锁日志可以知道死锁成因,死锁发生的位置,以及数据库做出的处理

  • 查看锁等待时间 (默认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;
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/873678.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号