MySQL查看锁的代码怎么写
本文小编为大家详细介绍“MySQL查看锁的代码怎么写”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL查看锁的代码怎么写”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
MySQL查看锁的sql
查看数据库状态
# 会显示加锁的信息等等show engine innodb status;
查看正在执行的线程信息
show full processlist;
查看正在锁的表
show open tables where in_use > 0;show open tables;
查看锁的类型、状态
show status like '%lock%';
0后,增加了3个关于锁的表
MySQL5.7版本
INFORMATION_SCHEMA.innodb_trx 当前运行的所有事务
INFORMATION_SCHEMA.innodb_locks 当前出现的锁
INFORMATION_SCHEMA.innodb_lock_waits 锁等待的对应关系
MySQL8.0版本
0后,performance_schema.data_locks代替了INFORMATION_SCHEMA.innodb_locks ,performance_schema.data_lock_waits代替了INFORMATION_SCHEMA.innodb_lock_waits
查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 5.7SELECT * FROM performance_schema.data_locks; -- 8.0
查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 5.7SELECT * FROM performance_schema.data_lock_waits; -- 8.0
查看行锁情况
show status like 'InnoDB_row_lock%';
查看表锁情况
show status like 'table%';
开启锁监控
开启监控后,可以看到锁的具体信息以及加锁顺序等,更容易分析死锁。
方式一:创建监控表,监控某个数据库
开启:
CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;
关闭:
DROP TABLE innodb_lock_monitor;
注意:在未拥有设置全局属性权限下也可以开启该功能。
方式二,开启全局监控
开启:
set GLOBAL innodb_status_output=ON;set GLOBAL innodb_status_output_locks=ON;
关闭:
set GLOBAL innodb_status_output=OFF;set GLOBAL innodb_status_output_locks=OFF;
查看数据库状态
show engine innodb status \G;
其他监控
标准监控(Standard InnoDB Monitor):监视活动事务持有的表锁、行锁;事务锁等待;线程信号量等待;文件IO请求;buffer pool统计信息;InnoDB主线程purge和change buffer merge活动。
# 方式一CREATE TABLE innodb_monitor (a INT) ENGINE=INNODB;DROP TABLE innodb_monitor;# 方式二set GLOBAL innodb_status_output=ON;set GLOBAL innodb_status_output=OFF;
锁监控(InnoDB Lock Monitor):提供额外的锁信息。
# 方式一CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;DROP TABLE innodb_lock_monitor;# 方式二set GLOBAL innodb_status_output=ON;set GLOBAL innodb_status_output_locks=ON;set GLOBAL innodb_status_output=OFF;set GLOBAL innodb_status_output_locks=OFF;
表空间监控(InnoDB Tablespace Monitor):显示共享表空间中的文件段以及表空间数据结构配置验证。
CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;DROP TABLE innodb_tablespace_monitor;
表监控(InnoDB Table Monitor):显示内部数据字典的内容。
CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;DROP TABLE innodb_tablespace_monitor;
读到这里,这篇“MySQL查看锁的代码怎么写”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341