mysql慢查询日志开启和存储格式

mysql版本号是mysql5.6.22。安装环境windows7。

1.使用该查询日志能够找到有效率问题的sql语句。并记录下来,进行监控。

能够使用例如以下语句查询和设置慢查询日志

(1) 查看慢查询日志是否开启

SHOW VARIABLES LIKE ‘%show_query_log%‘; 或是 SHOW VARIABLES LIKE ‘%show_query_log%‘\G (mysql命令行中使用)

查询结果例如以下

Variable_name: slow_query_log

Value: OFF

上边Value表示未开启

Variable_name: slow_query_log_file

Value: D:\ProgramFiles\MySQL5.6.22\mysql_master\data\LHY-slow.log

上边Value表示日志存放的路径

设置开启状态:

set global slow_query_log = on;

(2) 查看未使用索引的查询日志是否开启

SHOW VARIABLES LIKE ‘%log_queries_not_using_indexes%‘; 或是 SHOW VARIABLES LIKE ‘%log_queries_not_using_indexes%‘\G (mysql命令行中使用)

查询结果例如以下

Variable_name: log_queries_not_using_indexes

Value: OFF

上边Value表示未开启

设置开启状态:

set global log_queries_not_using_indexes = on;

(3) 查看超过设定时间的查询日志

SHOW VARIABLES LIKE ‘%long_query_time%‘; 或是 SHOW VARIABLES LIKE ‘%long_query_time%‘\G (mysql命令行中使用)

查询结果例如以下:

Variable_name: long_query_time

Value: 10.000000

上边value:10s表示记录运行时间超过10秒的sql

设置运行时间为1s

set global long_query_time = 1;

exit;

注意1:改动运行之间之后要退出又一次登录才会起作用.

注意2:设置时间过短导致日志记录过多会非常快将磁盘空间沾满,所以应该定期运行磁盘清理,这里设置为1是为了查看运行效果,生产环境中须要自己设置.

以上三个步骤运行完毕之后,从数据库中运行不论什么sql语句就都会被记录到日志中,能够到第一步中那个日志查看日志信息.

以上设置是在控制台处理的,当数据库重新启动之后,该设置即失效;

长期有效的方式是在mysql安装文件夹下找到my.ini文件,若是没有该文件,仅仅有mysql-default.ini文件

那么就将该文件备份,然后改名为mysql.ini。然后在该文件里[mysqld]下边加入例如以下的配置信息就可以。

slow_query_log=on

slow_query_log_file=D:/ProgramFiles/MySQL5.6.22/mysql_master/data/LHY-slow.log

log_queries_not_using_indexes=on

long_query_time=1

2.存储格式

# Time: 150401 11:24:27

# [email protected]: root[root] @ localhost [127.0.0.1]  Id:     7

# Query_time: 0.034002  Lock_time: 0.000000 Rows_sent: 3  Rows_examined: 3

use libu;

SET timestamp=1427858667;

select * from aaa;

分析例如以下:

(1) Time: 运行时间

(2) [email protected]: 运行sql的主机信息

(3) Query_time: sql的运行信息,Lock_time: 锁定时间, Rows_sent: 发送(结果)行数, Rows_examined:扫描的行数

(4) timestamp: 运行时间

(5) select * from aaa; : 查询语句内容

3.慢查询日志分析工具

    5种工具: mysqldumpslow,mysqlsla,myprofi,mysql-explain-slow-log,mysqllogfilter

mysqldumpslow mysql自带的分析工具

  致歉:本人眼下还未找到这些工具在window上使用的方式。若是哪位大神有相关的教程,请@我,谢谢!。。

时间: 2024-10-08 05:25:41

mysql慢查询日志开启和存储格式的相关文章

Mysql慢查询日志脚本

#!/bin/bash LOG=/diskb/mysql/slowlog/   #定义日志存储路径 DATE=`date +"%Y-%m-%d"`   #定义时间参数 user=root                                 #填写MySQL账户信息 passwd=123456 mysql -u$user -p$passwd -e "set global slow_query_log=0" #停止mysql慢查询日志 mysql -u$us

Mysql慢查询日志过程

原创地址 :http://itlab.idcquan.com/linux/MYSQL/922126.html mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出代码实现中耗费资源的sql语句,对我们程序的优化有很高的参考.本篇主要将慢查询日志的开启,日志分析,这也是优化SQL程序的一般步骤中至关重要的一步. 1.mysql慢查询日志 打开mysql的慢查询日志很简单,只需要在mysql的配置文件里(windows系统是my.ini,linux系统是my.cnf)的[mysqld]下面加

MySQL慢查询日志相关的配置和使用。

MySQL慢查询日志提供了超过指定时间阈值的查询信息,为性能优化提供了主要的参考依据,是一个非常实用的功能,MySQL慢查询日志的开启和配置非常简单,可以指定记录的文件(或者表),超过的时间阈值等就可以记录到慢sql了,实话讲,相比较sqlserver的trace或者扩展事件(虽然此二者的作用并非仅仅如此),MySQL的配置总是给人一种非常清爽的感觉. 1,慢查询日志的打开 正常情况下,只需要在配置文件中增加slow_query_log = 1配置,即打开慢查询日志,未指定slow_query_

使用Mysql慢查询日志对有效率问题的SQL进行监控

输入命令:show variables like 'slow%' 可以发现 slow_query_log 为 OFF(默认),表示未开启慢查询日志 slow_query_log_file 为慢查询日志文件 开启慢查询日志有两种方法 方法一: 临时开启        set global slow_query_log = on; #没有使用索引的sql将会被记录入慢查询日志        set global log_queries_not_using_indexes = on;   #查询时间大

Anemometer+Percona Toolki实现MySQL慢查询日志可视化功能

最近发现了一个挺好用的MySQL慢查询日志可视化的工具,网上也能找到很多资料,在这里结合自己的实际情况重新整理一下. 1. 实验环境 1.1 系统环境: 操作系统:CentOS 6.5 64位 主机地址:10.0.0.26 主机名:mysql01 mysql版本:mysql-5.6.36 1.2 可视化软件环境: http环境:LAMP 可视化软件:Anemometer-master.zip, percona-toolkit-3.0.11-1.el6.x86_64.rpm, perl-TermR

MySQL慢查询日志相关的文件配置和使用。

MySQL慢查询日志提供了超过指定时间阈值的查询信息,为性能优化提供了主要的参考依据,是一个非常实用的功能,MySQL慢查询日志的开启和配置非常简单,可以指定记录的文件(或者表),超过的时间阈值等就可以记录到慢sql了,实话讲,相比较sqlserver的trace或者扩展事件(虽然此二者的作用并非仅仅如此),MySQL的配置总是给人一种非常清爽的感觉. 1,慢查询日志的打开 正常情况下,只需要在配置文件中增加slow_query_log = 1配置,即打开慢查询日志,未指定slow_query_

MySQL慢查询日志总结转

MySQL慢查询日志总结 慢查询日志概念 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中.long_query_time的默认值为10,意思是运行10S以上的语句.默认情况下,Mysql数据库并不启动慢查询日志,需要我们手动来设置这个参数,当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响.慢查询日志支持将日志记

mysql慢查询日志分析工具mysqlsla

一.介绍    mysqlsla是一个分析mysql慢日志的工具,可以分析出慢查询的原因,包括执行某条sql出现的次数及在slow log数据的百分比.执行时间.等待销的时间等. 公司的数据库有很多慢查询日志,导致的系统的负载很高,而mysql慢查询日志文件内容格式不太好看,经推荐使用mysqlsla:使用方便,操作简单. 二.安装mysqlsla 系统环境 CentOS release 6.6 (Final) 2.6.32-504.el6.x86_64 官网已经不能下载,所需要的文件已在百度云

ELK logstash 处理MySQL慢查询日志(初步)

写在前面:在做ELK logstash 处理MySQL慢查询日志的时候出现的问题: 1.测试数据库没有慢日志,所以没有日志信息,导致 IP:9200/_plugin/head/界面异常(忽然出现日志数据,删除索引后就消失了) 2.处理日志脚本问题 3.目前单节点 配置脚本文件/usr/local/logstash-2.3.0/config/slowlog.conf[详细脚本文件见最后] output { elasticsearch { hosts => "115.28.3.150:9200