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

用MySQL分析SQL的耗时问题

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

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


慢日志查询

MySQL的慢日志查询是MySQL提供的一种日志记录,它用了记录在MySql中响应时间超过阈值的语句,具体运行时间超过long_query_time值的SQL,则会被记录到慢日志中。long_query_time的默认时间为10,意思是运行10以上的语句。

比如一条sql执行超过5秒钟,我们就算慢SQL,MySQL会记录超过5秒的sql,我们可以结合explain进行全面分析。

默认情况下,MySQL数据库没有开启慢查询日志,需要我们手动来设置这个参数。当然,如果不是调优需要,一般不建议启动该参数,因为慢日志会或多或少带来一定的性能影响。

是否开启以及设置

#查看是否开启show variables like '%slow_query_log%';#开启set global slow_query_log = 1;

使用set global slow_query_log=1开启了慢查询日志只对当前数据库生效,如果MySQL重启后则会失效。如果要永久生效,就必须修改配置文件my.cnf。

注意设置慢查询阈值时间后,你可能看不到值发生了变化,即没有生效,这时需要重新连接或新开一个会话才能看到修改值。

show variables like '%long_query_time%'

或者不重开连接也可以使用下面的命令:

show variables like '%long_query_time%'

哪些sql会被慢日志记录,这是由参赛long_query_time控制,默认情况下long_query_time的值为10秒,命令:

show variables like '%long_query_time%';

假如运行时间正好等于long_query_time的情况,并不会被记录下来。也就是说,在mysql是判断大于long_query_time,而非大于等于。

可以用下面的语句做个测试

SELECT sleep(4)

如果你设置的long_query_time为3秒,那么这条语句就会被记录下来。

这里写图片描述

查看慢日志条数

show global status like '%slow_queries%'

 日志分析工具mysqldumpslow

在生产环境中,如果要手工分析日志,查找、分析SQL,显然是个体力活,MySql提供了日志分析工具mysqldumpslow。

例如:

#得到返回记录集最多的10个SQL
Mysqldumpslow –s r –t 10 D:\Program Files\mysql\data\DESKTOP-VN2D5OU-slow.log#得到访问次数最多的10个SQL
Mysqldumpslow –s c –t 10 D:\Program Files\mysql\data\DESKTOP-VN2D5OU-slow.log#得到按照时间排序的前10条里面含有左连接的查询
Mysqldumpslow –s t –t 10 –g “left join” D:\Program Files\mysql\data\DESKTOP-VN2D5OU-slow.log#另外建议在使用这些命令时结合|和more使用,否则可能出现爆破情况
Mysqldumpslow –s r –t 10 D:\Program Files\mysql\data\DESKTOP-VN2D5OU-slow.log|more
参数含义
s: 表示按照何种方式排序
c:访问次数
l:锁定时间
r:返回记录
t:查询时间
al:平均锁定时间
t:返回前面多少条的数据
g:后面搭配一个正则表达式

用show profile进行sql分析

show profile命令可以分析当前会话中语句执行的资源消耗情况。用于查找SQL耗时瓶颈 。默认处于关闭状态,并保存最近15次的运行结果。

查看是否开启(show variables like ‘profiling’;)
开启功能(set profiling = on;)

开启之后就可以记录接下来sql的运行情况。之后通过show profiles来查看结果:

这里写图片描述

进一步通过命令(show profile cpu, block io for query 3;)分析某个SQL语句执行情况,例如下面分析3号SQL的情况。

这里写图片描述

Show profile后面的一些参数:

  • All:显示所有的开销信息

  • Block io:显示块IO相关开销

  • Context switches: 上下文切换相关开销

  • Cpu:显示cpu相关开销

  • Memory:显示内存相关开销

  • Source:显示和source_function,source_file,source_line相关的开销信息

全局查询日志

(永远不要在生产环境开启,查看所有执行的SQL语句)

设置命令:

set global general_log = 1;#以表的形式输出set global log_output = ‘TABLE’

此后,mysql所执行的SQL语句将会记录到mysql.genearl_log表,可用下面的命令查看:

select * from mysql.general_log;

也可以在配置文件中配置,设置如下:

#开启General_log = 1#记录日志文件的路径General_log_file = D://path/logfile#输出格式Log_output=file
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

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

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

相关文章

  • 2018-12-05Oracle 数据库中创建合理的数据库索引
  • 2018-12-05SQLServer 循环批处理
  • 2018-12-05如何在eclipse中通过jdbc连接mysql数据库
  • 2018-12-05讲解有关sqlserver分页查询处理方法
  • 2018-12-05plsql连接oracle数据库报ora 12154错误解决方法
  • 2018-12-05解析mysql的自连接和join关联
  • 2018-12-05分享SQLCipher数据库如何加解密
  • 2018-12-05MySQL数据库中如何进行子查询
  • 2017-05-11在WIN命令提示符下mysql 用户新建、授权、删除,密码修改
  • 2017-05-11mysql数据库导出xml的实现方法

文章分类

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

最近更新的内容

    • 存储过程优缺点分析
    • 虚拟主机MySQL数据库的备份与还原的方法
    • MySQL笔记之数据备份与还原的使用详解
    • oracle if else语句使用介绍
    • mysql 动态执行存储过程语句
    • mysql 导入导出数据库、数据表的方法
    • 详解MySQL误操作后怎样进行数据恢复_MySQL
    • Linux下安装与使用MySQL详细介绍
    • 索引是什么?MySQL如何创建索引
    • linux下mysql的一点基本用法

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

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