• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > Mysql分析-show PROCESSLIST 的详情

Mysql分析-show PROCESSLIST 的详情

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了Mysql,show ,PROCESSLIST等相关知识,希望本文的分享对您有所帮助

上回做一个投票系统,一道活动高峰期久卡的要命,临时调高带宽效果也不明显。

上服务器进行分析,top里面大量的CPU都消耗在IO wait上。种种迹象都指向mysql,又是慢日志查询,又是查看索引结构,都感觉没找到根本问题。终于,在show processlist的时候发现了由大量的lock进程。哈哈,问题显而易见嘛。

该投票表使用的是mysiam引擎,投票量起来以后update把表给锁了,加上服务器性能一般处理慢,程序在处理投票页面的时候也没有异步降级,综合因素把导致很卡。但关键因素还是找到了,是因为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

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2017-05-11MySQL定时器开启、调用实现代码
  • 2018-12-05详解linux采用binary方式安装mysql
  • 2018-12-05简单的数据库权限分配教程
  • 2018-12-05mysql基础使用浅谈(1)_MySQL
  • 2017-05-11MySQL数据类型和常用字段属性总结
  • 2018-12-05linux忘记mysql密码处理方法
  • 2018-12-05 【MySQL 12】触发器
  • 2018-12-05如何远程修复损坏的mysql数据库
  • 2018-12-05sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
  • 2018-12-05SQLServer 数据库的数据汇总完全解析(WITH ROLLUP)

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql数值类型
    • MYSQL索引建立需要注意以下几点细节
    • mysql 协议的ColumnDefinition包及解析代码详情
    • MySql 错误Incorrect string value for column
    • MySQL的23个需要注意的地方
    • Oracle11.2 命令行手工最简创建数据库的过程
    • mysql中insert与select的嵌套使用方法
    • 有关Uber的文章推荐10篇
    • Access的平均间隔控件使用
    • DDL语句的实例详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有