美文网首页
MySQL查询是否锁表/事物、查询进程

MySQL查询是否锁表/事物、查询进程

作者: 乐百氏vic | 来源:发表于2019-08-26 10:57 被阅读0次

1、查询是否锁表

show OPEN TABLES where In_use > 0;

查询到相对应的进程 === 然后 kill id

2、查询进程

show processlist

查看正在锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

查看等待锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

1 show processlist;

SHOW PROCESSLIST显示哪些线程正在运行。您也可以使用mysqladmin processlist语句得到此信息。如果您有SUPER权限,您可以看到所有线程。否则,您只能看到您自己的线程(也就是,与您正在使用的MySQL账户相关的线程)。如果有线程在update或者insert 某个表,此时进程的status为updating 或者 sending data。

如果您得到“too many connections”错误信息,并且想要了解正在发生的情况,本语句是非常有用的。MySQL保留一个额外的连接,让拥有SUPER权限的账户使用,以确保管理员能够随时连接和检查系统(假设您没有把此权限给予所有的用户)。

大部分状态对应很快的操作,只要有一个线程保持同一个状态好几秒钟,那么可能是有问题发生了,需要检查一下。还有其他的状态没在上面中列出来,不过它们大部分只是在查看服务器是否有存在错误是才用得着。

2 show full processlist;

show processlist;只列出前100条,如果想全列出请使用show full processlist;

3 show open tables;

这条命令能够查看当前有那些表是打开的。In_use列表示有多少线程正在使用某张表,Name_locked表示表名是否被锁,这一般发生在Drop或Rename命令操作这张表时。所以这条命令不能帮助解答我们常见的问题:当前某张表是否有死锁,谁拥有表上的这个锁等。

show open tables from database;

4 show status like ‘%lock%’

查看服务器状态。

5 show engine innodb statusG;

MySQL 5.1之前的命令是:show innodbstatusG;,MySQL 5.5使用上面命令即可查看innodb引擎的运行时信息。

6 show variables like ‘%timeout%’;

查看服务器配置参数。

参考资料

mysql5.0经常出现 err=1205 - Lockwait timeout exceeded; try restarting transaction

http://www.imysql.cn/node/165

mysql show processlist命令详解

http://www.cnblogs.com/JulyZhang/archive/2011/01/28/1947165.html

MySQL锁

http://blog.csdn.net/c__ilikeyouma/article/details/8541195

SHOW INNODB STATUS提示语法错误?

http://www.itpub.net/thread-1454597-1-1.html

SHOW OPEN TABLES – what is in your tablecache

相关文章

网友评论

      本文标题:MySQL查询是否锁表/事物、查询进程

      本文链接:https://www.haomeiwen.com/subject/tmhrectx.html