美文网首页PHP实战java web 学习我用 Linux
Mysql性能优化之开启Mysql慢查询日志

Mysql性能优化之开启Mysql慢查询日志

作者: 思梦PHP | 来源:发表于2016-12-25 10:51 被阅读105次

    查看当前服务器是否开启慢查询:

    1、快速办法,运行sql语句show VARIABLES like "%slow%"

    2、直接去my.conf中查看。

    my.conf中的配置(放在[mysqld]下的下方加入)

    [mysqld]

    log-slow-queries = /data/mysql/10-9-138-42-slow.log

    long_query_time = 1 #单位是秒

    log-queries-not-using-indexes

    使用sql语句来修改:不能按照my.conf中的项来修改的。修改通过"show VARIABLES like "%slow%" "

    语句列出来的变量,运行如下sql:

    set global log_slow_queries = ON;

    set global slow_query_log = ON;

    set global long_query_time=0.1; #设置大于0.1s的sql语句记录下来

    之后呢重启Mysql的数据库:使用 service 启动:service mysqld start

    慢查询日志文件的信息格式:

    select sleep(3); 这个就是关键信息,指明了当时执行的是这条语句

    设置毫秒级别与mysql版本的关系

    很多网上资料显示,5.21之前的版本,在my.conf中的long_query_time最小只能设置为1(也就是最小1秒)。我自己歪打误撞,发现我通过其他方式可以实现。

    "long_query_time = 0.1"这种方式我没试,因为数据库服务器在跑。需要重启。所以没试。我是通过全局变量设置实现慢日志查询记录的。

    可以通过全局变量设置方式实现毫秒级别记录:

    set global long_query_time = 0.01

    我服务器上mysql版本为:5.5.53

    我试过这种方式有效。

    怎么测试自己的查询是否

    会被记录下来呢?

    运行语句

    select sleep(3);

    我故意设置3秒延迟,然后这条语句按照预期(因为之前设置超过0.1秒)会被记录到日志文件中去。

    相关文章

      网友评论

        本文标题:Mysql性能优化之开启Mysql慢查询日志

        本文链接:https://www.haomeiwen.com/subject/abwrvttx.html