首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >慢查询日志不存储慢速查询。

慢查询日志不存储慢速查询。
EN

Database Administration用户
提问于 2017-04-07 17:01:01
回答 2查看 3.5K关注 0票数 1

使用5.6.35 MySQL社区服务器(GPL)。我已经设置了本地MySQL实例,如下所示

代码语言:javascript
复制
show variables like '%slow%query%log%'

slow_query_log  ON
slow_query_log_file /usr/local/mysql/data/MacBook-Pro-slow.log

general_log ON

但我没有看到任何查询被登录

代码语言:javascript
复制
SELECT * FROM mysql.slow_log;

SELECT * FROM mysql.general_log

两张桌子都是空的。我正在运行超过20秒的查询,并且我的阈值设置得很好。有什么建议吗?

EN

回答 2

Database Administration用户

发布于 2017-04-10 10:55:33

收集一般日志和慢速日志有两种方法:

  • 文件(这是默认的)
  • 表(这需要具体启用)

根据您提供的信息,MySQL似乎使用了log_output的默认值,即“由general_log_file和slow_query_log_file定义的日志输出文件(S)”。您可以通过查看这些文件(查看文件夹/usr/local/mysql/data/并查看哪些*.log文件)来验证这一点。

如果希望日志转到数据库,则在以特权用户身份登录时,在MySQL客户机上,例如root:

  • SET GLOBAL log_output='TABLE';
  • SET GLOBAL general_log=ON;
  • SET GLOBAL slow_query_log=ON;
  • SET GLOBAL long_query_time=0;

以上内容将向mysql.general_logmysql.slow_log表发送全局日志和慢速日志。

注意,我已经将long_query_time设置为0秒,即每个查询都指向slow_log(这是表中的大量输出)。您可以将其更改为适合您的用例的另一个值。

而且,general_log会产生大量的日志,因此您应该只在一定的时间内启用它。

票数 1
EN

Database Administration用户

发布于 2017-04-08 01:21:30

默认情况下(在您的情况下也是如此),将缓慢和通用的日志保存信息保存到普通OS文件中。

在您的情况下,慢速日志文件:

代码语言:javascript
复制
/usr/local/mysql/data/MacBook-Pro-slow.log

无法从mysql内部访问此文件中的数据。

您可以通过编辑器手动打开它,也可以使用- 查询摘要之类的专门工具打开它。

如果希望在表中包含这些数据,则需要启用对表- https://dev.mysql.com/doc/refman/5.7/en/server-options.html#option_米舍尔德_测井输出的写入。

票数 0
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/169484

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档