经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
MySQL查看锁的实现代码
来源:jb51  时间:2023/2/8 8:56:27  对本文有异议

MySQL查看锁的sql

查看数据库状态

  1. # 会显示加锁的信息等等
  2. show engine innodb status;

查看正在执行的线程信息

  1. show full processlist;

查看正在锁的表

  1. show open tables where in_use > 0;
  2. show open tables;

查看锁的类型、状态

  1. show status like '%lock%';

5.0后,增加了3个关于锁的表

MySQL5.7版本

  • INFORMATION_SCHEMA.innodb_trx 当前运行的所有事务
  • INFORMATION_SCHEMA.innodb_locks 当前出现的锁
  • INFORMATION_SCHEMA.innodb_lock_waits 锁等待的对应关系

MySQL8.0版本

8.0后,performance_schema.data_locks代替了INFORMATION_SCHEMA.innodb_locks ,performance_schema.data_lock_waits代替了INFORMATION_SCHEMA.innodb_lock_waits

查看正在锁的事务

  1. SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 5.7
  2. SELECT * FROM performance_schema.data_locks; -- 8.0

查看等待锁的事务

  1. SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 5.7
  2. SELECT * FROM performance_schema.data_lock_waits; -- 8.0

查看行锁情况

  1. show status like 'InnoDB_row_lock%';

查看表锁情况

  1. show status like 'table%';

开启锁监控

开启监控后,可以看到锁的具体信息以及加锁顺序等,更容易分析死锁。

方式一:创建监控表,监控某个数据库

开启:

  1. CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;

关闭:

  1. DROP TABLE innodb_lock_monitor;

注意:在未拥有设置全局属性权限下也可以开启该功能。

方式二,开启全局监控

开启:

  1. set GLOBAL innodb_status_output=ON;
  2. set GLOBAL innodb_status_output_locks=ON;

关闭:

  1. set GLOBAL innodb_status_output=OFF;
  2. set GLOBAL innodb_status_output_locks=OFF;

查看数据库状态

  1. show engine innodb status \G;

其他监控

标准监控(Standard InnoDB Monitor):监视活动事务持有的表锁、行锁;事务锁等待;线程信号量等待;文件IO请求;buffer pool统计信息;InnoDB主线程purge和change buffer merge活动。

  1. # 方式一
  2. CREATE TABLE innodb_monitor (a INT) ENGINE=INNODB;
  3. DROP TABLE innodb_monitor;
  4. # 方式二
  5. set GLOBAL innodb_status_output=ON;
  6. set GLOBAL innodb_status_output=OFF;

锁监控(InnoDB Lock Monitor):提供额外的锁信息。

  1. # 方式一
  2. CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;
  3. DROP TABLE innodb_lock_monitor;
  4. # 方式二
  5. set GLOBAL innodb_status_output=ON;
  6. set GLOBAL innodb_status_output_locks=ON;
  7. set GLOBAL innodb_status_output=OFF;
  8. set GLOBAL innodb_status_output_locks=OFF;

表空间监控(InnoDB Tablespace Monitor):显示共享表空间中的文件段以及表空间数据结构配置验证。

  1. CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;
  2. DROP TABLE innodb_tablespace_monitor;

表监控(InnoDB Table Monitor):显示内部数据字典的内容。

  1. CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;
  2. DROP TABLE innodb_tablespace_monitor;

到此这篇关于MySQL查看锁的实现代码的文章就介绍到这了,更多相关MySQL查看锁内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号