【伍哥原创】

在我们做系统性能调优的时候,数据库的慢查询语句的优化是必不可少的,特别是电子商务类型的重度MYSQL应用类型。

下面我们一起来看看怎么做好MYSQL的慢查询分析吧。

1,开启MYSQL的慢查询日志

首先在my.cnf配置里面加入慢查询配置,然后建立慢查询的日志文件,并把用户和组修改为mysql,最后重启mysqld。

接着测试一下慢查询是否生效,可以访问一下phpmyadmin或者跑一条select sleep(1),然后再cat一下/var/log/mysql-slow.log,如果看到有记录就表示设置成功了。不过,生成慢查询日志只是忠实的 记录了每一条慢查询,对于我们做分析并不方便。

2,安装mysqlsla慢查询分析工具

3,慢查询统计

打开其中一个log统计文件,你会看到:

Report for slow logs: /var/log/mysql-slow.log

被分析的慢查询日志文件

40 queries total, 12 unique

40条查询;除了重复的,有12条查询

Sorted by ‘t_avg’

按平均查询时间排序

Grand Totals: Time 4 s, Lock 0 s, Rows sent 236, Rows Examined 8.63k

______________________________________________________________________ 001 ___

Count : 1 (2.50%)这条SQL出现了1次,占SQL总数的2.5%

Time : 588.994 ms total执行时间总和, 588.994 ms avg平均每次查询的时间, 588.994 ms最短时间 to 588.994 ms max最长时间 (13.78%)

Lock Time (s) : 91 µs total, 91 µs avg, 91 µs to 91 µs max (2.34%)

Rows sent : 30 avg, 30 to 30 max (12.71%)

Rows examined : 899 avg, 899 to 899 max (10.41%)

Database :

Users :

coreseektest@localhost : 100.00% (1) of query, 100.00% (40) of all users

Query abstract:

SET timestamp=N; SELECT * FROM ecm_goods WHERE goods_name LIKE ‘S’ ORDER BY ecm_goods.brand_id ASC LIMIT N, N;

Query sample:

SET timestamp=1341467496;

SELECT * FROM `ecm_goods` WHERE goods_name like ‘冰箱’ ORDER BY `ecm_goods`.`brand_id` ASC

LIMIT 0, 30;

______________________________________________________________________ 002 ___

Count : 2 (5.00%) 这条SQL出现了2次,占SQL总数的5%

Time : 57.38 ms total 执行时间总和, 28.69 ms avg 平均每次查询的时间, 27.503 ms 最短时间 to 29.877 ms max 最长时间 (1.34%)

Lock Time (s) : 134 µs total, 67 µs avg, 64 µs to 70 µs max (3.44%)

Rows sent : 3 avg, 3 to 3 max (2.54%)

Rows examined : 3 avg, 3 to 3 max (0.07%)

Database :

Users :

coreseektest@localhost : 100.00% (2) of query, 100.00% (40) of all usersQuery abstract:

SET timestamp=N; SELECT * FROM documents LIMIT N, N;

Query sample:

SET timestamp=1341399487;

SELECT * FROM `documents` LIMIT 0, 30;

…其他省略…

如果需要做更复杂的统计,可以参考官方文档:http://hackmysql.com/mysqlsla_guide

如果希望每隔一段时间,比如一天,出一次慢查询统计的话,可以写一个shell脚本,然后放到/etc/crontab里面。这样的话,就可以定期做查询优化。

【全文完 】

mysql 8.0 慢查询_MySQL慢查询分析相关推荐

  1. 审计MySQL 8.0中的分类数据查询

    面临的挑战 通常,涉及到敏感信息时用户需要使用审计日志.不仅仅是在表上运行Select,还包括访问表中的特定单元格.通常,这类数据将包含一个分类级别作为行的一部分,定义如何处理.审计等策略. 诸如此类 ...

  2. mysql 8.0 慢查询_MySQL慢查询 - 开启慢查询

    一.简介 开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能. 二.参数说明 slow_query_log 慢查询开启状态 slow_ ...

  3. mysql 内嵌查询_mysql嵌套查询_MySQL

    mysql嵌套查询_MySQL 一:创建ecs_goods表插入以下数据: +----------+------------------------------+--------+---------- ...

  4. mysql 日志抓取变化_MySQL慢查询日志分析提取【转】

    原文:https://www.cnblogs.com/skymyyang/p/7239010.html 一:查询slow log的状态,如示例代码所示,则slow log已经开启. mysql> ...

  5. mysql 分号子查询_MySQL子查询详解

    子查询指一个查询语句嵌套在另一个查询语句内部的查询,这个特性从 MySQL 4.1 开始引入,在 SELECT 子句中先计算子查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或者多个表 ...

  6. 怎样知道mysql的驱动是什么_MySQL连接查询到底什么是驱动表?看了这里你应该就明白了...

    作者:阿伟~ 链接:https://www.cnblogs.com/sy270321/p/12760211.html 准备我们需要的表结构和数据 两张表 studnet(学生)表和score(成绩)表 ...

  7. MySQL实验四数据库的查询_MySQL数据库查询(实验四)

    MySQL数据库查询 准备工作:脚本文件xkgl.sql下载:xkgl脚本.sql 1.执行脚本xkgl.sql (创建xkgl库.表及插入数据),观察有无错误,如有记录错误信息,并解决. (1) 执 ...

  8. mysql对结果再查询_mysql 再查询结果的基础上查询(子查询)

    SELECT A.wx_name, A.wx_litpic, B . * FROM ( SELECT uid, COUNT( * ) AS daticishu FROM statements WHER ...

  9. mysql数据库的查询_mysql数据库查询

    查询数据指从数据库中获取所需要的数据.查询数据是数据库操作中最常用,也是最重要的操作.用户可以根据自己对数据的需求,使用不同的查询方式.通过不同的查询方式,可以获得不同的数据.MySQL中是使用SEL ...

  10. java mysql 分页查询_MySQL分页查询方法及优化

    当数据库的数据量很大时,一次性查询结果就会变得很慢,为了提高查询效率,我们可以使用MySQL的分页查询功能.本文就为大家带来MySQL分页查询方法及优化. 推荐阅读: 分页查询方法: 在MySQL中, ...

最新文章

  1. poj 2728 Desert King(最小比率生成树 / 0-1分数规划 / 二分)
  2. 《WEB渗透一.信息收集》
  3. 信息学奥赛一本通 2066:【例2.3】买图书
  4. ES6——Class 的继承 笔记
  5. treeset可以重复吗_java容器(五)HashSet与TreeSet
  6. Linux内核调度——《奔跑吧Linux内核》学习笔记
  7. ASP.NET MVC 3.0(十二): MVC 3.0 使用自定义的Html控件
  8. 2021年压力焊工作业考试题库
  9. C++的Memcpy与Memcpy_s函数解析
  10. matlab 标准色度图,采用Matlab图像进行有色溶液样液浓度测试
  11. 从玄学走向科学:在字节跳动广告投放这么干
  12. 1、多线程原理与实践 《Java高并发核心编程 卷二》读书笔记
  13. DVD驱动器打开拒绝访问
  14. 计算机建立第2用户,2016年计算机二级VF备考练习题及参考答案(5)
  15. hazy的面试小笔记之Java(持续更新)
  16. 下一代CDN如何与智能AI及物联网打通?
  17. NDCG介绍、实现及在推荐系统中的应用实践
  18. POJ 1723 士兵排队 C语言实现
  19. 分享一个开源的QT的串口示波器
  20. 简单的stm32入门小程序(交通信号灯)STM32F103C8T6

热门文章

  1. Oracle数据库教程
  2. AI识虫:林业病虫害数据集和数据预处理方法
  3. matlibplot 一张图画多个曲线_一文读懂磁滞回曲线
  4. excel 两组数据交点_Python 自动化测试(四):数据驱动
  5. IntelliJ IDEA安装
  6. 非主流图片编辑软件_快火拼多多直播发言软件怎么下载
  7. java遍历文件夹并把所有文件放到list中
  8. 给echarts添加筛选时间控件时,控件不显示,并设置数据库无数据时echarts模块显示暂无数据
  9. LeetCode 10 正则表达式匹配
  10. 浙江理工大学2019年5月赛