MySQL show processlist

时间:2021-01-11 11:13:40   收藏:0   阅读:0

show processlist和show full processlist

processlist命令的输出结果显示了有哪些线程在运行,不仅可以查看当前所有的连接数,还可以查看当前的连接状态帮助识别出有问题的查询语句等。( processlist 返回的结果是实时变化的,是对mysql链接执行的现场快照,所以用来处理突发事件非常有用。

如果是root帐号,能看到所有用户的当前连接。如果是其他普通帐号,则只能看到自己占用的连接。show processlist只能列出当前100条。

如果想全部列出,可以使用SHOW FULL PROCESSLIST命令。

这个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中的【工具】=> 【服务器监控】进行查看。」

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

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


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

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;
--正在running的线程
Select count(*)from information_schema.processlist where info is not null;
--Mysql的全部线程
Select count(*)from information_schema.processlist;
--查询当前running sql执行时间最长的10条
Select * from information_schema.processlist where info is not null order by time desc limit10 ;
--查询执行sql的ip 的连接数量
select left(host,instr(host,‘:‘)-1) asip,count(*) as num from information_schema.processlist group by ip order by num desc;
--查询执行sql的user的连接数量
select user,count(*) as num from  information_schema.processlist group by userorder by num desc;
--查询执行sql语句的数量
select count(*) as num,info from  information_schema.processlist where info isnot null group by info order by num;
--查询mysql服务器最大连接数、当前数据库连接数和running数show global variables like ‘max_connections‘;
show global status like ‘Threads%‘;

--查询用户最大连接数

show grants for ‘mysql_bi‘;

 

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!