慢查询日志(mysql)

摘要:
MySQL慢查询是MySQL提供的日志记录。它用于记录mysql中响应时间超过阈值的sql语句。如果某个sql的运行时间超过了设置的阈值,它将被记录在慢速查询日志中。阈值的默认值为10s。默认情况下,MySQL数据库不会启动慢速查询日志。您需要手动设置此参数。TABLE表示将日志保存到数据库中,以便将日志信息写入mysql.slow_log表。

参考

针对mysql的优化,mysql提供了慢查询日志的支持。mysql的慢查询是mysql提供的一种日志记录,它用来记录mysql中响应时间超过阀值的sql语句,某个sql运行时间如果超过设置的阀值(long_query_time),就会被记录到慢查询日志中。阀值默认值是10s,默认情况下,mysql数据库并不会启动慢查询日志,需要手动来设置这个参数(slow_query_log)。慢查询日志支持将日志写入文件,也支持将日志写入数据库表。一般不建议开启慢查询日志,因为慢查询日志或多或少带来一定的性能影响。

慢查询日志相关参数

慢查询日志(mysql)第1张慢查询日志(mysql)第2张
1 slow_query_log    :是否开启慢查询日志,1表示开启,0表示关闭。
2 log-slow-queries  :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
3 slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
4 long_query_time :慢查询阈值,当查询时间多于设定的阈值时,记录日志。
5 log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。
6 log_output:日志存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据<br>库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需<br>要能够获得更高的系统性能,那么建议优先记录到文件。
View Code

慢查询日志(mysql)第3张

 慢查询日志(mysql)第4张

慢查询日志(mysql)第5张

慢查询日志(mysql)第6张

慢查询日志(mysql)第7张

 慢查询日志(mysql)第8张

使用set命令开启慢查询日志,mysql重启之后会失效,如果要永久生效,将配置写入到mysql的配置文件my.cnf或my.ini文件中

慢查询日志(mysql)第9张

开启慢查询日志之后,执行时间超过阀值的sql会被记录下来,在mysql5.1之前,long_query_time存的是整数,5.1开始,long_query_time以微妙记录sql运行时间

将阀值由10s修改为2.13s

慢查询日志(mysql)第10张

log_output参数指定日志的存储方式,FILE表示将日志存入文件,默认值是FILE。TABLE表示将日志存入数据库,这样日志信息会被写入到mysql.slow_log表中。mysql数据库支持同时两种日志方式记录,配置的时候用逗号分隔即可。日志记录到系统的专用日志表中要比记录到文件耗费更多的系统资源,对于慢查询日志,建议优先记录到文件中。

将日志存储方式修改为同时支持两种存储方式

慢查询日志(mysql)第11张

慢查询日志信息

文件

慢查询日志(mysql)第12张

系统表

慢查询日志(mysql)第13张

系统变量log_slow_admin_statements表示是否将慢管理语句比如analyze table和alter table等计入慢查询日志

慢查询日志(mysql)第14张

想查询有多少条慢查询记录,可以使用系统变量

慢查询日志(mysql)第15张

分析慢查询日志如果单纯去看,很耗费时间,效率不高,可以使用mysqldumpslow或pt_query_digest工具,具体参考

免责声明:文章转载自《慢查询日志(mysql)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Java并发实现线程阻塞原语LockSupportAngularJs一些记录下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Mybatis操作Mysql批量更新的一个坑-&amp;amp;allowMultiQueries=true允许批量更新

前言           利用Mybatis批量更新或者批量插入,实际上即使Mybatis完美支持你的sql,你也得看看你操作的数据库是否完全支持,而同事,最近就遇到这样的一个坑! 问题         先带大家来看一段sql的配置:      1 <update id="updateAllAvailable"> 2 <foreach...

ubuntu 14.04 源码编译mysql-5.7.17

环境为 Ubuntu 12.04 64 位的桌面版 编译的mysql 版本为 5.7.18 首先需要安装一下依赖包 sudo apt-get install libncurses5-dev cmake chkconfig 创建用户组和用户 mysql groupadd mysql useradd -r -g mysql -s /bin/bash mysq...

Go Mysql Driver 集成 Seata-Golang 解决分布式事务问题

简介: 2020 年 4 月,我们开始尝试实现 go 语言的分布式事务框架 Seata-Golang。众所周知,Seata AT 模式以无业务代码侵入的特点,被广大开发者推崇。Java 版 Seata AT 模式通过对 DataSource 数据源进行代理,在 sql 语句执行时,对 sql 拦截解析,获取数据库对应数据在 sql 语句执行前后的副本,序列...

MySQL查询性能优化

1.为什么查询速度为变慢 在尝试编写快速的查询之前,需要清楚一点,真正重要是响应时间。如果把查询看作是一个任务,那么他由一系列子任务组成,每个子任务都会消耗一定的时间。如果要优化查询,实际上要优化其子任务,要么消除其中一些子任务,要么减少子任务的执行的次数,要么让子任务运行得更快。 MySQL在执行查询的时候有哪些子任务。哪些子任务运行的速度很慢,这里很难...

常见ArcGIS操作(以10.0为例)

文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.建立缓冲区 先在图层属性表里面新建一个缓冲区半径字段,然后对该字段赋值。比如设置字段值为道路宽度的一半。选择刚才创建的字段来生成缓冲区,也可以选择线性单位生产同样半径的缓冲区。 2.等距离将线转点 该操作分为两步走,第一步利...

centos5.2下配置opensips1.9笔记

1、vimyum -y install vim-enhanced(推荐)(http://www.cnblogs.com/jenry/archive/2013/06/13/3134215.html) 2、ifconfig su 进入root,运行vim /etc/profile 在文件末加入以下语句:   PATH=$PATH:/sbin #在PATH变量...