天天看点

mysql慢查询

  有时我们为了定位系统中效率比较低下的Query语法,需要打开慢查询日志,也就是SlowQuery log。打开慢查询日志的相关命令如下:

查看

mysql> showvariables like '%slow%';

+---------------------+-------------------------------------------+

|Variable_name       |Value                                    |

|log_slow_queries    |ON                                       |

|slow_launch_time    |2                                        |

|slow_query_log      |ON                                       |

| slow_query_log_file| /app/mysql-5.5.32/data/localhost-slow.log |

4 rows in set (0.00sec)

mysql> show globalstatus like '%slow%';

+---------------------+-------+

|Variable_name       | Value |

| Slow_launch_threads| 0     |

|Slow_queries        |0     |

2 rows in set (0.00sec)

打开慢查询日志可能会对系统性能有一点点影响,如果你的MySQL是主从结构,可以考虑打开其中一台从服务器的慢查询日志,这样既可以监控慢查询,对系统性能影响也会很小。另外,可以用MySQL自带的命令mysqldumpslow进行查询。

比如:下面的命令可以查出访问次数最多的20个SQL语句:

[root@localhost ~]#mysqldumpslow -s c -t 20  /app/mysql-5.5.32/data/localhost-slow.log

注意:

-s ORDER     what to sort by (al, at, ar, c, l, r, t), 'at' isdefault

               al: average lock time

               ar: average rows sent

               at: average query time

                c: count

                l:lock time

                r: rows sent

                t: query time 

 -t NUM       just show the top n queries

版权声明:原创作品,如需转载,请注明出处。否则将追究法律责任

本文转自    鹏爱   51CTO博客,原文链接:http://blog.51cto.com/pengai/1890364