MySql中怎样查询表是否被锁
MySql查询表是否被锁
查看表被锁状态
# 查询哪些表锁了 show OPEN TABLES where In_use > 0;
查看造成死锁的sql语句
# 查询innodb引擎的运行时信息 show engine innodb status;
查询进程
# 查询所有进程 show processlist;
解锁(删除进程)
# 删除进程 kill id;
查看正在执行的事务
# 查看正在执行的事务 select * from information_schema.INNODB_TRX;
查看正在锁的事物
# 查看正在锁的事物 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS
查看等待锁的事物
# 查看等待锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
MySql出现数据库表被锁解决方案
出现的现象
页面出现502错误,数据库CPU持续飙升,大量事务堆积未提交成功(事务一直处于阻塞阶段)
查看阻塞事务列表,发现其中有锁表现象。
排查与解决思路
1)查看数据库中是否有表被锁
show open tables where in_use > 0;
如果上述返回有结果,说明有表正在被使用,返回字段如下
| Database | Table | In_use | Name_locked |
2)查看进程(只会显示当前用户的进程,除非是root用户)
show processlist;
3)查看当前运行所有事务
SELECT * FROM information_schema.INNODB_TRX;
4)查看当前出现的所有锁
SELECT * FROM information_schema.INNODB_LOCKs;
5)查询锁等待的对应关系
SELECT * FROM information_schema.INNODB_LOCK_waits;
查看事务表 INNODB_TRX中 是否有正在锁定的事务线程
确认 ID 是否在 show processlist 的 sleep 线程中:如果在,说明这个sleep的线程事务一直没有commit 或者 rollback,而是卡住了,需要手动kill掉。
搜索的结果中,如果在事务表发现了很多任务,最好都 kill 掉。
6)清理事务指定的线程 ID
kill 1234;
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Red Hat 安装MySQL 8.0与 Navicat的详细过程
这篇文章主要介绍了Red Hat安装MySQL8.0与Navicat,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08MySQL基础教程第一篇 mysql5.7.18安装和连接教程
这篇文章主要为大家详细介绍了MySQL基础教程第一篇,mysql5.7.18安装和连接教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-05-05mysql DISTINCT选取多个字段,获取distinct后的行信息方式
这篇文章主要介绍了mysql DISTINCT选取多个字段,获取distinct后的行信息方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-01-01mysql-8.0.35-winx64 zip版安装教程(附图文)
许多人在学习过程中经常因使用不当将MySQL数据库搞崩溃,这篇文章主要给大家介绍了关于mysql-8.0.35-winx64 zip版安装教程的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下2024-01-01
最新评论