MySQL问题定位---使用\'show processlis\'

本文介绍了一种 MySQL 的 System Lock 异常现象及其排查方法。客户端执行 SQL 命令后,服务器出现无响应状态,通过 show processlist 命令查看线程状态并定位问题。

调试MySQ一个Lbug,现象如下:

1 客户端1,执行了一条SQL命令:  execute s;

  其中,'s' 由prepare语句定义

2 命令开始执行后,服务器在运行(察看进程存在,并不独有内存变化,或高或低,表明内存有分配和释放动作)

3 客户端1没有接受到反馈, 停在回车键被按下之后没有回现的状态.

4 开启新的客户端2, 执行命令: show processlist;

   看到如下内容:

MySQL问题定位---使用show processlis - 那海蓝蓝 - 那海蓝蓝的博客

 "State"列暴露了问题所在,为什么服务器看似没有反应,原来是发生了"System lock".

5 一条SQL命令之后,MySQL服务器没有反应,咱们办? ---第一个可用的方法,就是执行第四步的命令.

 

MySQL官方手册说:

 SHOW PROCESSLIST shows you which threads are running. You can also get this information from the INFORMATION_SCHEMA PROCESSLIST table or the mysqladmin processlist command.

而"State"列的值,可能有哪些? 更多内容参考:官方手册  8.13.5.2 General Thread States

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值