文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mysql慢查询日志的过程

2024-04-02 19:55

关注

这篇文章主要介绍“Mysql慢查询日志的过程”,在日常操作中,相信很多人在Mysql慢查询日志的过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mysql慢查询日志的过程”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出代码实现中耗费资源的sql语句,对我们程序的优化有很高的参考。本篇主要将慢查询日志的开启,日志分析,这也是优化SQL程序的一般步骤中至关重要的一步。
  1.mysql慢查询日志
  打开mysql的慢查询日志很简单,只需要在mysql的配置文件里(windows系统是my.ini,linux系统是my.cnf)的[mysqld]下面加上
  Java代码
  log-slow-queries=mysql_slow.log
  long_query_time=3
  其中log-slow-queries为日志的文件名,可以指定目录,如log-slow- queries=D:\mysql_slow.log; long_query_time为定义多长的查询我们定义为慢查询,并记录在log-slow-queries 指定的文件中,在这里我们定义超过3秒的查询进行记录。
  配置完成以后重启Mysql服务器,执行show variables like '%slow%';查看慢查询日志是否开启,如果slow_query_log和log_slow_queries显示为on,那说明服务器的慢查询日志已
  经开启了。如下显示:
  Java代码
  mysql> show variables like '%slow%';
  +---------------------+----------------+
  | Variable_name       | Value          |
  +---------------------+----------------+
  | log_slow_queries    | ON             |
  | slow_launch_time    | 2              |
  | slow_query_log      | ON             |
  | slow_query_log_file | mysql_slow.log |
  +---------------------+----------------+
  4 rows in set (0.00 sec)
  slow_launch_time跟慢查询日志没有任何关系, 它代表的是thread create的一个阈值,如果要看 long_query_time,可以用
  Java代码
  mysql> show variables like '%long%';
  +-----------------+----------+
  | Variable_name   | Value    |
  +-----------------+----------+
  | long_query_time | 3.000000 |
  +-----------------+----------+
  1 row in set (0.00 sec)
  2.mysql慢查询日志分析
  建表如下图,建表勿要给text加上索引,否则可能出现不了超过3秒的查询,数据表填充了4194304条数据。

 
  我们来执行一个超过3秒的查询,如下:
  Java代码
  mysql> select * from wei where text='orange';
  +---------+--------+
  | id      | text   |
  +---------+--------+
  | 4103519 | orange |
  +---------+--------+
  1 row in set (3.79 sec)
  再执行一个超过3秒的和一个没有超过3秒的:
  Java代码
  mysql> select * from wei where text='xishizhaohua';
  Empty set (3.82 sec)
  Java代码
  [mysql> select * from wei where id=4564;
  +------+--------------------+
  | id   | text               |
  +------+--------------------+
  | 4564 | yyyyyyyyyyyyyyyyyy |
  +------+--------------------+
  1 row in set (0.02 sec)
  可以通过下面的命令查看现在这个session有多少个慢查询:

 
  现在我们可以查看mysql_slow.log(win7默认在C:\ProgramData\MySQL\MySQL Server 5.1\data下面),里边内容如下,内容比较明了,包括查询花费的语句及时间,还包括查询时的时间戳等信息,其中Rows_examined为检查的 行数,对我们优化也很有帮助
  # Time: 121017 17:38:54
  # User@Host: root[root] @ localhost [127.0.0.1]
  # Query_time: 3.794217 Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 4194304
  SET timestamp=1350466734;
  select * from wei where text='orange';
  # Time: 121017 17:46:22
  # User@Host: root[root] @ localhost [127.0.0.1]
  # Query_time: 3.819219  Lock_time: 0.000000 Rows_sent: 0  Rows_examined: 4194304
  SET timestamp=1350467182;
  select * from wei where text='xishizhaohua';

到此,关于“Mysql慢查询日志的过程”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯