百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> MySQL神器之show full processlist
分享文章到:

MySQL神器之show full processlist

发布时间:09/01 来源:未知 浏览: 关键词:
今天在同步测试数据时,网忽然断了,比及重连之后,发明表打不开了。

可以看到表的数据长度已有 112192kb,惋惜打不开了。

打不开,就预备删掉重来。

事情往往没这么简便,公然删不掉,truncate 也不可,然后 navicat 卡死,遂登上数据库,施行 dorp 操纵,还是不可。

估量是网络错误,致使了一些惊奇的事情发生。

那么就一起看看,到底发生了什么吧。

神器登场。

show full processlist;

show full processlist 返回的结果是实时转变的,是对 mysql 链接施行的现场快照,所以用来处置突发事件非常有用。

这个 sql,一样就是充当救火队员的角色,解决一些突发性的问题。

它可以查看当前 mysql 的一些运转状况,可否有压力,都在施行什么 sql,语句耗时几何,有没有慢 sql 在施行等等。

当发明一些施行时间很长的 sql 时,就需要多留意一下了,必要时 kill 掉,先解决问题。

命令有三种施行方式:

1、这种是直接在命令行查询,末尾带 \G 是表示将查询结果停止按列打印,可以使每个字段打印到独自的行。

mysql> show full processlist;
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| Id     | User | Host                 | db    | Command | Time | State    | Info                  |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| 449000 | root | 127.123.213.11:59828 | stark | Sleep   | 1270 |          | NULL                  |
| 449001 | root | 127.123.213.11:59900 | stark | Sleep   | 1241 |          | NULL                  |
| 449002 | root | 127.123.213.11:59958 | stark | Sleep   | 1216 |          | NULL                  |
| 449003 | root | 127.123.213.11:60088 | stark | Sleep   | 1159 |          | NULL                  |
| 449004 | root | 127.123.213.11:60108 | stark | Sleep   | 1151 |          | NULL                  |
| 449005 | root | 127.123.213.11:60280 | stark | Sleep   | 1076 |          | NULL                  |
| 449006 | root | 127.123.213.11:60286 | stark | Sleep   | 1074 |          | NULL                  |
| 449007 | root | 127.123.213.11:60344 | stark | Sleep   | 1052 |          | NULL                  |
| 449008 | root | 127.123.213.11:60450 | stark | Sleep   | 1005 |          | NULL                  |
| 449009 | root | 127.123.213.11:60498 | stark | Sleep   |  986 |          | NULL                  |
| 449013 | root | localhost            | NULL  | Query   |    0 | starting | show full processlist |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
11 rows in set (0.01 sec)
mysql> show full processlist\G;
*************************** 1. row ***************************
     Id: 449000
   User: root
   Host: 127.123.213.11:59828
     db: stark
Command: Sleep
   Time: 1283
  State: 
   Info: NULL
*************************** 2. row ***************************
     Id: 449001
   User: root
   Host: 127.123.213.11:59900
     db: stark
Command: Sleep
   Time: 1254
  State: 
   Info: NULL

2、通过查询链接线程相关的表来查看快照

SELECT id, db, USER, HOST, command, time, state, info FROM information_schema. PROCESSLIST WHERE command != 'Sleep' ORDER BY time DESC;

3、通过 navicat 中的【工具】=> 【效劳器监控】停止查看。

这种方式比力利便,还可以排序。

简便介绍一下,每列的含义:

Id:链接 mysql 效劳器线程的独一标识,可以通过 kill 来终止此线程的链接。

User:当前线程链接数据库的会员

Host:显示这个语句是从哪个 ip 的哪个端口上发出的。可用来追踪出问题语句的会员

db: 线程链接的数据库,假如没有则为 null

Command: 显示当前连接的施行的命令,一样就是休眠或余暇(sleep),查询(query),连接(connect)

Time: 线程处在当前状态的时间,单位是秒

State:显示使用当前连接的 sql 语句的状态,很重要的列,后续会有所有的状态的描写,请留意,state 只是语句施行中的某一个状态,一个 sql 语句,已查询为例,大概需要经过 copying to tmp table,Sorting result,Sending data 等状态才可以完成

Info: 线程施行的 sql 语句,假如没有语句施行则为 null。这个语句可以使客户端发来的施行语句也可以是内部施行的语句

发明问题之后怎样解决它呢?

1、可以独自 kill 掉上面有问题的行

kill 449000

2、也可以大量完毕时间超越 3 分钟的线程

-- 查询施行时间超越3分钟的线程,然后拼接成 kill 语句

select concat('kill ', id, ';')

from information_schema.processlist

where command != 'Sleep'

and time > 3*60

order by time desc;

当然问题到这,一样都能解决了,但是本次在 show processlist 历程中,只是看到了前面的 truncate 和 drop 操纵,把这两个线程 kill 了,也没何用。。。。

当然上面这些不是废话昂,这就是相似办法论的东西,就像【我国机长】里面,碰到航行变乱时,第一依照手册,检查一遍,排查缘由,解决问题。

连续

紧接着,又用 navicat 施行了修复表操纵,结果返回了 Waiting for table metadata lock

当 MySQL 在停止一些 alter table 等 DDL 操纵时,假如该表上有未提交的事务则会显现 Waiting for table metadata lock,而一旦显现 metadata lock,该表上的后续操纵都会被堵塞。

解决方法:

1、从 information_schema.innodb_trx 表中查看当前未提交的事务

select trx_state, trx_started, trx_mysql_thread_id, trx_query from information_schema.innodb_trx\G

字段意义:

trx_state: 事务状态,一样为 RUNNING

trx_started: 事务施行的起始时间,若时间较长,则要剖析该事务可否合理

trx_mysql_thread_id: MySQL 的线程 ID,用于 kill

trx_query: 事务中的 sql

一样只要 kill 掉这些线程,DDL 操纵就不会 Waiting for table metadata lock。

2、调整锁超时阈值

lock_wait_timeout 表示猎取 metadata lock 的超时(单位为秒),同意的值范畴为 1 到 31536000(1 年)。 默许值为 31536000。

详见 https://dev.mysql.com/doc/refman/5.6/en/se...

默许值为一年。。。。

将其调整为 30 分钟

set session lock_wait_timeout = 1800;

set global lock_wait_timeout = 1800;

好让显现该问题时快速失败(failfast)。

引荐教程:《MySQL教程》《Navicat》

以上就是MySQL神器之show full processlist的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有152人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板