如何启用MySQL慢查询日志并在Linux上进行分析?

  1. 通过SSH连接到Plesk服务器  

  2. 在MySQL配置文件中启用MySQL慢查询日志my.cnf

    2.1。my.cnf在任何文本编辑器中打开文件在这个例子中,我们使用的是“vi”编辑器

    2.2。添加以下[mysqld]部分下面的记录

    slow_query_log = 1
    log-slow-queries = /var/log/mysql-slow.log
    long_query_time = 2

    Note: In MySQL 5.7, the variable log-slow-queries is deprecated. Use slow_query_log_file instead.

    2.3。保存更改并关闭文件。

    • 其中long_query_time - SQL查询在几秒钟内执行所花费的时间。如果查询的时间超过指定的值,则此查询将记录在慢查询日志文件中。

    • 基于CentOS / RHEL的发行版上:

      # vi /etc/my.cnf

    • Debian / Ubuntu的发行版上:

      # vi /etc/mysql/my.cnf

  3. 创建慢速查询日志文件/var/log/mysql-slow.log(http://www.2fgk.com)并为其设置正确的所有权:

    # touch /var/log/mysql-slow.log
    # chown mysql:mysql /var/log/mysql-slow.log

  4. 重启MySQL。该命令取决于操作系统和已安装的MySQL版本:

    • 基于CentOS / RHEL的发行版:

      # service mysqld restart

    • 对于基于Debian / Ubuntu的发行版:

      # service mysql restart

    • 如果安装了MariaDB

      # service mariadb restart

  5. 开始监视慢速查询日志文件。使用命令  mysqldumpslow对其进行分析并打印慢查询日志文件的摘要。
    例如,要打印已记录的所有慢速查询,请运行以下命令:

    # mysqldumpslow -a /var/log/mysql-slow.log

    mysqldumpslow选项的完整列表请参见此处


猜你喜欢

转载自blog.51cto.com/14202983/2351473