0


MySQL查看锁的sql

MySQL查看锁的sql

查看数据库状态

# 会显示加锁的信息等等showengineinnodbstatus;

查看正在执行的线程信息

showfull processlist;

查看正在锁的表

showopentableswhere in_use >0;showopentables;

查看锁的类型、状态

showstatuslike'%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

查看正在锁的事务

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

查看行锁情况

showstatuslike'InnoDB_row_lock%';

查看表锁情况

showstatuslike'table%';

开启锁监控

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

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

开启:

CREATETABLE innodb_lock_monitor (a INT)ENGINE=INNODB;

关闭:

DROPTABLE innodb_lock_monitor;

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

方式二,开启全局监控

开启:

setGLOBAL innodb_status_output=ON;setGLOBAL innodb_status_output_locks=ON;

关闭:

setGLOBAL innodb_status_output=OFF;setGLOBAL innodb_status_output_locks=OFF;

查看数据库状态

showengineinnodbstatus \G;

其他监控

  • 标准监控(Standard InnoDB Monitor):监视活动事务持有的表锁、行锁;事务锁等待;线程信号量等待;文件IO请求;buffer pool统计信息;InnoDB主线程purge和change buffer merge活动。# 方式一CREATETABLE innodb_monitor (a INT)ENGINE=INNODB;DROPTABLE innodb_monitor;# 方式二setGLOBAL innodb_status_output=ON;setGLOBAL innodb_status_output=OFF;
  • 锁监控(InnoDB Lock Monitor):提供额外的锁信息。# 方式一CREATETABLE innodb_lock_monitor (a INT)ENGINE=INNODB;DROPTABLE innodb_lock_monitor;# 方式二setGLOBAL innodb_status_output=ON;setGLOBAL innodb_status_output_locks=ON;setGLOBAL innodb_status_output=OFF;setGLOBAL innodb_status_output_locks=OFF;
  • 表空间监控(InnoDB Tablespace Monitor):显示共享表空间中的文件段以及表空间数据结构配置验证。CREATETABLE innodb_tablespace_monitor (a INT)ENGINE=INNODB;DROPTABLE innodb_tablespace_monitor;
  • 表监控(InnoDB Table Monitor):显示内部数据字典的内容。CREATETABLE innodb_tablespace_monitor (a INT)ENGINE=INNODB;DROPTABLE innodb_tablespace_monitor;
标签: mysql sql 数据库

本文转载自: https://blog.csdn.net/blood_Z/article/details/128779095
版权归原作者 万山寒 所有, 如有侵权,请联系我们删除。

“MySQL查看锁的sql”的评论:

还没有评论