MySQL执行状态分析

标签: mysql 状态 分析 | 发表时间:2016-01-28 05:23 | 作者:u010870518
出处:http://blog.csdn.net

当感觉mysql性能出现问题时,通常会先看下当前mysql的执行状态,使用 show processlist 来查看,例如:

这里写图片描述

其中state状态列信息非常重要,先看下各列含义,然后看下state常用状态

各列的含义

1、id

一个标识,你要kill一个语句的时候使用,例如 mysql> kill 207;

2、user

显示当前用户,如果不是root,这个命令就只显示你权限范围内的sql语句

3、host

显示这个语句是从哪个ip 的哪个端口上发出的,可用来追踪出问题语句的用户

4、db

显示这个进程目前连接的是哪个数据库

5、command

显示当前连接的执行的命令,一般就是休眠(sleep),查询(query),连接(connect)

6、time

此这个状态持续的时间,单位是秒

7、state

显示使用当前连接的sql语句的状态,很重要的列,state只是语句执行中的某一个状态,例如查询,需要经过copying to tmp table,Sorting result,Sending data等状态才可以完成

8、info

显示这个sql语句,因为长度有限,所以长的sql语句就显示不全,但是一个判断问题语句的重要依据

state 常见状态分析

1、Sleep

通常代表资源未释放,如果是通过连接池,sleep状态应该恒定在一定数量范围内,例如:

数据查询时间为0.1秒,而网络输出需要1秒左右,原本数据连接在0.1秒即可释放,但是因为前端程序未执行close操作,直接输出结果,那么在结果未展现在用户桌面前,该数据库连接一直维持在sleep状态

2、Locked

操作被锁定,通常使用innodb可以很好的减少locked状态的产生

3、Copy to tmp table

索引及现有结构无法涵盖查询条件时,会建立一个临时表来满足查询要求,产生巨大的i/o压力Copy to tmp table通常与连表查询有关,建议减少关联查询或者深入优化查询语句,如果出现此状态的语句执行时间过长,会严重影响其他操作,此时可以kill掉该操作

4、Sending data

Sending data并不是发送数据,是从物理磁盘获取数据的进程,如果你的影响结果集较多,那么就需要从不同的磁盘碎片去抽取数据,如果sending data连接过多,通常是某查询的影响结果集过大,也就是查询的索引项不够优化

5、Storing result to query cache

如果频繁出现此状态,使用 set profiling分析,如果存在资源开销在SQL整体开销的比例过大(即便是非常小的开销,看比例),则说明query cache碎片较多,使用 flush query cache可即时清理,Query cache参数可适当酌情设置

作者:u010870518 发表于2016/1/27 21:23:57 原文链接
阅读:0 评论:0 查看评论

相关 [mysql 状态 分析] 推荐:

MySQL执行状态分析

- - CSDN博客推荐文章
当感觉mysql性能出现问题时,通常会先看下当前mysql的执行状态,使用 show processlist 来查看,例如:. 其中state状态列信息非常重要,先看下各列含义,然后看下state常用状态. 一个标识,你要kill一个语句的时候使用,例如 mysql> kill 207;. 显示当前用户,如果不是root,这个命令就只显示你权限范围内的sql语句.

MySQL锁定状态查看命令

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

Mysql查看连接数、状态

- - CSDN博客数据库推荐文章
如果是root帐号,你能看到所有用户的当前连接,如果是其它普通帐号,只能看到自己占用的连接. show processlist只能列出前100条;如果想全列出请使用show full processlist. show status like ‘%变量%’. Aborted_clients 由于客户没有正确关闭连接已经死掉,已经放弃的连接数量.

Mysql 查看连接数,状态

- - 数据库 - ITeye博客
命令: show processlist;. 如果是root帐号,你能看到所有用户的当前连接. 如果是其它普通帐号,只能看到自己占用的连接. show processlist;只列出前100条,如果想全列出请使用show full processlist;. 命令: show status;. 命令:show status like '%下面变量%';.

Mysql 查看连接数,状态

- - 互联网 - ITeye博客
来源  http://blog.csdn.net/starnight_cbj/article/details/4492555. 命令: show processlist;. 如果是root帐号,你能看到所有用户的当前连接. 如果是其它普通帐号,只能看到自己占用的连接. show processlist;只列出前100条,如果想全列出请使用show full processlist;.

Mysql 大数据操作状态查询

- - SegmentFault 最新的文章
这种时候我们就应该祭出一些方法了,在这里我总结一下我查到的资料. 在mysql中执行这个语句后,就能显示出mysql正在执行和处理哪些语句,以及相应的其他信息. Id: 40 User: root Host: localhost db: dbname Command: Query Time: 2061 State: Sending data Info: insert into table t1(*) select * from t2.

分析 Kubernetes Nodes ‘Not Ready’ 状态

- -
节点是 Kubernetes 集群的重要组成部分,负责运行 pod. 根据您的集群设置,节点可以是物理机或虚拟机. 一个集群通常有一个或多个节点,这些节点由控制平面管理. 由于节点负责管理工作负载,因此您需要确保所有节点都正常运行. 该 kubectl get nodes命令可用于检查节点的状态.

MySQL锁表机制分析

- - 小彰
为了给高并发情况下的mysql进行更好的优化,有必要了解一下mysql查询更新时的锁表机制. MySQL有三种锁的级别:页级、表级、行级. MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level. locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁.

MySQL锁阻塞分析

- - CSDN博客数据库推荐文章
日常维护中,经常会碰到线程被阻塞,导致数据库响应非常慢,下面就看看如何获取是哪个线程导致了阻塞的. blog地址: http://blog.csdn.net/hw_libo/article/details/39080809. 3.1  使用show processlist查看. | | 3 | root | localhost | test | Query | 70 | Sending data | select count(*) from t3 a,t3 b.

使用HAProxy对MySQL进行负载均衡和状态监控

- Kevin - Michael`s blog
转载请保留原文内容,并声明转载地址:http://www.toplee.com/blog/1284.html. 乐搜(lesoo.com)使用HAProxy已经很久了,但主要用在前端web请求的负载均衡和状态监控上,对于后端的Memcached以及MySQL却一直没有应用,最近对系统架构进行了小规模的整理,把MySQL也收编到了HAProxy下,经过一段时间的使用,体验还是不错的.