mysql processlist 解释_MySQL Processlist 讲解

Processlist 简介

Processlist 命令可以实时查询mysql当前有哪些运行的进程。

执行命令: show processlist

上述命令就可以查看进程运行情况,使用这个方法可以有效的查询当前mysql 的状态,并进行及时的调整。

Processlist 列表介绍

d8054ab91f5cf8408b263d56c2204006.png

Id:顾名思义,代表当前执行的操作的id。

User:代表操作的用户。

Host:代表当前请求的ip地址和端口号。

db:数据库名称。

Command:当前执行命令。一般会有sleep,query,daemon

sleep: 当前命令是休眠状态。说明当前操作对mysql保持连接,但是目前没有操作。

query: 最主要操作,数据库主要操作,crud都属于这类操作。

daemon: 守护命令。通常是事件的操作,事件定时执行任务,当前可能在等待。如下图:

8b7385961242cee3c2f3993fd7a35f2f.png

这个连接状态就是daemon,user 变成了 event_scheduler。State 的描述表明当前状态是等待下一次任务执行。

Time:当前等待的时间。单位:秒。

State:当前执行命令的状态。

Info:显示执行的语句。如第一张图显示了查询和删除的sql语句。

Processlist 分析案例

1. 程序报错  too many  connections。遇到这个问题,多半是因为太多命令在连接mysql,通过show processlist ,可以查看到当前所有执行情况,对于不再继续使用的sleep 的command的执行命令,可以使用kill id来结束连接。

2. 如果同时连接请求数过大,可以先查询 show variables like "max_connections";,之后执行命令  set GLOBAL max_connections=1000;来修改 最大连接数。

3. 根据time来设置timeout相关数值。如set global wait_timeout=200;来设置等待过期时间。默认wait_timeout 为28800。如果根据mysql中命令休眠的情况来设置时间,尽可能少,这样可以使得sleep进程即使释放。

3e7c2d3c284e194675b682a8ec8cb7f3.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值