mysql慢查询日志默认在哪里_MySQL 慢查询日志[通俗易懂]

mysql慢查询日志默认在哪里_MySQL 慢查询日志[通俗易懂]慢查询日志概念MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中查询响应时间超过阈值的语句,具体指响应时间超过long_query_time值的SQL,会被记录到慢查询日志。long_query_time的默认值是10s,意思是查询响应时间超过10s的SQL语句。默认情况下,MySQL是不开启慢查询日志的,需要我们手动设置这个参数值,当然,如果…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

慢查询日志概念

MySQL 的慢查询日志是 MySQL 提供的一种日志记录,它用来记录在 MySQL 中查询响应时间超过阈值的语句,具体指响应时间超过

long_query_time 值的 SQL,会被记录到慢查询日志。long_query_time 的默认值是 10s,意思是查询响应时间超过 10s 的 SQL语句。默

认情况下,MySQL 是不开启慢查询日志的,需要我们手动设置这个参数值,当然,如果不是调优需要的话,一般不建议开启慢查询日志,

因为开启慢查询日志或多或少会带来一定性能的影响。慢查询日志支持将日志记录写入日志文件,也支持将日志记录写入数据表。

慢查询日志参数

slow_query_log:表示是否开启慢查询日志,OFF表示禁用,ON表示开启

slow_query_log_file:MySQL 慢查询日志存储路径。可以不设置该参数,系统会默认给一个缺省值的文件host_name-slow.log

long_query_time:慢查询时间阈值,默认情况下值为 10s

log_queries_not_using_indexes:表示不使用索引的查询超出 long_time_query 的值也会被记录到日志中,默认值是 OFF表示禁用

log_output:表示存储慢查询日志方式,log_output=’FILE’ 表示将日志存入文件,log_output=‘TABLE’ 表示将日志存入数据表 mysql.slow_log

。MySQL 同时支持两种日志存储方式,配置的时候以逗号分隔开,如:log_output=’FILE,TABLE’。一般情况下建议将日志记录到

文件中,如果将日志记录到数据表中需要耗费更多系统资源

慢查询日志配置

默认情况下,slow_query_log 是禁用的,可以通过设置 slow_query_log 的值开启,如下所示:

ff09fdd93e5df0012905e83cb1f01ec6.png

开启慢查询日志:

286adf5d36a8d3fbd17e0e98be10688e.png

使用 set global slow_query_log=1 开启慢查询日志只对当前数据库生效,如果 MySQL 重启后则会失效。如果要永久生效,就需要修改配置文件

my.cnf(Linux 下的叫法),如果是 win 系统一般叫 my.ini,如如下所示:

修改 my.ini 文件,增加或修改参数 slow_query_log 和 slow_query_log_file 后,然后重启 MySQL 服务器,如下所示:

8936b56414095441f1b96c77518b6aa3.png

12572b6c5aab67050ee01a301bdac708.png

现在已经开启了慢查询日志,那么什么样的 SQL 才会被记录到日志中呢?这个就由 long_query_time 控制,默认情况下 long_query_time 的值为 10s,可

以使用命令修改,也可以通过修改配置文件修改,对于运行时间刚好等于 long_query_time 的情况是不会被记录下来的,如下:

a2d1f6c0b48ae9632baf3d8ba74a3948.png

修改 long_query_time 值

0bc54bd0af8d6583402508d72e532c7d.png

执行修改操作之后,需要重新连接或打开一个会话才能看到修改的值 或者 使用 show global variable like ‘%long_query_time%’ 查看

我们来测试一下,在 MySQL 中执行下面 SQL 语句,然后我们去检查对应的慢日志:

dbe03bb054ea861ff25984d4599f4c36.png

log_output 是用来指定存储日志的方式,操作如下:

a7e5d577ffea40043ff69ec2890e1abc.png

设置慢日志存储方式:

489ddccb6a4e826b9b592709dff72781.png

执行 select sleep(10); 如下所示:

0f110b63311cef09b411a6968ecfd787.png

5a0ca4a36a6d9c4a4c03f29a05cb47e3.png

系统变量 log_queries_not_using_indexes 未使用索引的查询也会被记录到慢日志中,如果调优的话,建议开启这个选项,开启这个选项后 index full scan 的sql 也会被记录到日志中

60c91a5ff10978c2cb7e37912a5157d8.png

c5672f3a356974649175fb835f40f5fb.png

291710ed3798a56a2e1da46a7f12a830.png

这个开启之后慢查询日志可能会增长的很快,可以设定 log_throttle_queries_not_using_indexes 变量来限制,默认值是 0,也就是不限制,如果该变量

值大于 0 如:log_throttle_queries_not_using_indexes = 100 表示每秒记录100条不使用索引的 SQL 语句到慢查询日志中

默认情况下,管理类的 SQL 语句也不会被记录到慢查询日志中,log_slow_admin_statements 变量表示是否将管理类的 SQL 语句记录到慢查询日中,管理

类的 SQL 语句包含:ALTER TABLE, ANALYZE TABLE, CHECK TABLE, CREATE INDEX, DROP INDEX, OPTIMIZE TABLE, and REPAIR TABLE

MySQL 的从库默认不记录慢查询,如果要开启从库的慢查询需要设定 log_slow_slave_statements

如果要查询有多少条慢查询记录,可以使用系统变量,如下:

1d3e6b4a275cd9f6784a39aec3513023.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182083.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm向左缩进_vscode整体缩进

    pycharm向左缩进_vscode整体缩进整体右移(缩进):鼠标全选住要缩进的代码,按tab整体左移(反缩进):鼠标全选住要缩进的代码,按tab+shift

    2022年8月25日
    3
  • tomcat部署war包 接口404 网页能访问「建议收藏」

    tomcat部署war包 接口404 网页能访问「建议收藏」后端新手部署项目被自己坑哭了。访问网页都知道加一个打包的war包名字,访问接口的时候没有加。http://xxx.xxx.xxx/项目名/页面路径页面基地址http://xxx.xxx.xxx/shop/例:http://xxx.xxx.xxx/shop/index.jsp接口基地址:http://xxx.xxx.xxx/shop例:http://xxx.xxx.xxx/shop/goods/getAllGoods…

    2022年6月1日
    30
  • ScheduledExecutorService 使用

    ScheduledExecutorService 使用ScheduledExecutorService,我平时没有用过,他的最大优点除了线程池的特性以外,可以实现循环或延迟任务。ScheduledExecutorService,是基于线程池设计的定时任务类,每个调度任务都会分配到线程池中的一个线程去执行,也就是说,任务是并发执行,互不影响。需要注意,只有当调度任务来的时候,ScheduledExecutorService才会真正启动一个线程,其余时间ScheduledExecutorService都是出于轮询任务的状态。先来个简单的延迟任务调…

    2022年6月2日
    33
  • 数据结构:图的存储结构之邻接矩阵「建议收藏」

    数据结构:图的存储结构之邻接矩阵「建议收藏」图的邻接矩阵(AdjacencyMatrix)存储方式是用两个数组来表示图。一个一维的数组存储图中顶点信息,一个二维数组(称为邻接矩阵)存储图中的边或弧的信息。设图G有n个顶点,则邻接矩阵是一个n*n的方阵,定义为:我们来看一个实例,图7-4-2的左图就是一个无向图。我们再来看一个有向图样例,如图7-4-3所示的左图。在图的术语中,我们提到了网的概念,也就

    2022年10月25日
    0
  • 360无线路由器dns服务器,路由器的首选dns服务器怎么填

    360无线路由器dns服务器,路由器的首选dns服务器怎么填满意答案mirk60422020.04.25采纳率:42%等级:7已帮助:159人1、在管理员界面中输入命令:ipconfig/all然后按enter键确认即可显示windowsip配置,在这里我们可以查看我们的dns服务器地址。2、如果你连接了路由的话也可以通过路由来查看你的dns服务器地址,在浏览器输入地址192.168.1.1弹出路由器登入对话框,通常路由器默认的账户密码均为:ad…

    2022年6月10日
    52
  • 如何保证docker2375端口的安全

    如何保证docker2375端口的安全情景再现:之前有很多朋友提过,当使用docker-maven-plugin打包SpringBoot应用的Docker镜像时,服务器需要开放2375端口。由于开放了端口没有做任何安全保护,会引起安全漏洞,被人入侵、挖矿、CPU飙升这些情况都有发生,今天我们来聊聊如何解决这个问题。问题产生的原因首先我们要明白问题产生的原因,才能更好地解决问题!Docker为了实现集群管理,提供了远程管理的端口。DockerDaemon作为守护进程运行在后台,可以执行发送到管理端口上的Docker命令。当我们修改do

    2022年6月13日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号