开启慢查询日志方法

文章介绍了如何开启MySQL或MariaDB的慢查询日志,设置查询时间限制,以及不记录未使用索引的SQL。通过修改全局变量如`slow_query_log`,`long_query_time`,并指定慢查询日志文件的位置,可以监控和优化数据库性能。如果设置后未生效,需新开session确认设置。
摘要由CSDN通过智能技术生成

步骤

  1. 开启慢查询日志

    SET GLOBAL slow_query_log = on;
    
    SHOW VARIABLES like 'slow_query_log';
    
  2. 设置时间限制

    SET GLOBAL long_query_time = 1; -- 单位s
    
    SHOW VARIABLES LIKE '%long_query_time%';
    

    因为long_query_time参数只对新的数据库连接生效,所以还需要重启msql客户端。

  3. 不记录未使用索引sql

    SET GLOBAL log_queries_not_using_indexes = 'off';
    
    SHOW VARIABLES LIKE '%log_queries_not_using_indexes%';
    
  4. 创建慢查询日志输出文件

    进入mariadb容器的/var/lib/mysql/目录,创建文件mariadb-slow.log

  5. 设置慢查询日志输出文件

    SET GLOBAL slow_query_log_file = '/var/lib/mysql/mariadb-slow.log';
    
    SHOW VARIABLES LIKE '%slow_query_log_file%';
    
  6. 查看慢查询日志
    可以进入容器,查看/var/lib/mysql/mariadb-slow.log文件。

Q&A

  1. 更新设置之后,查询结果显示未生效怎么办?

    答:重新开启一个新的session查询。例如,执行命令SET GLOBAL slow_query_log = on;后,再开启一个新的session执行命令SHOW VARIABLES like 'slow_query_log';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值