首页 > 数据库 >mysql 性能问题查找

mysql 性能问题查找

时间:2022-11-02 15:02:02浏览次数:46  
标签:语句 状态 性能 sql 查询 state 查找 mysql 连接

进程相关命令

1.显示哪些线程正在运行:只列出前100条
方法1 show processlist;
![](/i/l/?n=22&i=blog/2298258/202211/2298258-20221102113410395-378863373.png)
方法2 select * from information_schema.processlist; 可以看到完整的sql.
2.显示哪些线程正在运行:全列出
show full processlist;
3.杀掉指定mysql连接的进程id为第二步的第一列的id
kill id
其中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参数可适当酌情设置
MySQL数据库是常见的两个瓶颈是CPU和I/O的瓶颈,CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候。磁盘I/O瓶颈发生在装入数据远大于内存容量的时候,如果应用分布在网络上,那么查询量相当大的时候那么平瓶颈就会出现在网络上,我们可以用mpstat, iostat, sar和vmstat来查看系统的性能状态。
除了服务器硬件的性能瓶颈,对于MySQL系统本身,我们可以使用工具来优化数据库的性能,通常有三种:使用索引,使用EXPLAIN分析查询以及调整MySQL的内部配置。
在优化MySQL时,通常需要对数据库进行分析,常见的分析手段有慢查询日志,EXPLAIN 分析查询,profiling分析以及show命令查询系统状态及系统变量,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

事务

1、查看正在进行中的事务
SELECT * FROM information_schema.INNODB_TRX
2、查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
3、查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
4、查看当前有那些表是打开的,In_use列表示有多少线程正在使用某张表,Name_locked表示表名是否被锁查询是否锁表
SHOW OPEN TABLES where In_use > 0;
![](/i/l/?n=22&i=blog/2298258/202211/2298258-20221102112732464-2121289656.png)
在发生死锁时,这几种方式都可以查询到和当前死锁相关的信息。
##5、查看最近死锁的日志
show engine innodb status

标签:语句,状态,性能,sql,查询,state,查找,mysql,连接
From: https://www.cnblogs.com/lvshuizhicheng/p/16850526.html

相关文章

  • MySQL_连接查询_等值连接
    ·引例SELECTname,ageFROMstudents,teachersWHEREstudents.id=teachers.students_id; ·特点表的顺序:两个表的顺序可以调换可以加筛选:AND可以加分组:逗号隔......
  • MySQL_分组函数
    功能用作统计使用,又称为聚合函数或统计函数或组函数分类Sum求和Avg平均值Max最大值Min最小值Count计算个数特点1sum、avg一般用于处理数值型2以上分组函......
  • mysql绿色安装
     本文介绍mysql压缩包安装方式;压缩包下载地址:https://dev.mysql.com/downloads/mysql/5.5.html#downloads  解压下载好的压缩包文件:  打开文件,内容如下: ......
  • MySQL_分组查询
    语法Select分组函数,列(要求出现在groupby的厚民)From表【where筛选条件】Groupby分组的列表【orderby子句】注:查询列表必须特殊,要求是分组函数和groupby后出......
  • MySQL_单行函数
    常见函数:字符函数:LengthConcatSubstrInstrTrimUpperLowerLpadRpadReplace数学函数RoundCeilFloorTruncateMod日期函数NowCurdateCurtimeYearMonth......
  • MySQL_流程控制函数
    ·IF函数效果等同于Java中的 ifelse 函数SELECTIF(10<5,'大','小'); ·CASE函数 CASE要判断的字段或表达式WHEN常量1THEN要显示的值1或语句1;WHEN......
  • mysql_fdw安装使用
    环境:OS:Centos7pgdb:13.8mysqldb:5.7 1.安装fdw[root@localhostextension]#yumlistmysql_fdw*[root@localhostextension]#yuminstallmysql_fdw_13.x86_64[post......
  • linux mysql版本升级
    概述因检测当前版本5.7.36的mysql有一些漏洞,因此需要进行升级,本次升级将从5.7.36--->5.7.39,环境为CentOS7。旧版本使用的是rpm包的方式自行安装的,因此升级起来也就比较简......
  • Mysql导出导入操作
    编写sh文件cd/rootecho'开始导出数据:'+$(date+%F%n%T)>迁移RDS操作日志.txtecho'开始导出数据:'+$(date+%F%n%T)#导出数据,但不导出储存过程、触发器、函数、......
  • MySQL 跨服务器查询数据
    MySQL同个服务器下,要进行跨数据库进行查询,只需在表前加上数据库名就可以。如果要在跨服务器查询,服务器A查询服务器B,则需要在服务器A开启federated引擎(默认关闭)以进行映射表......