mysql or中有空查询慢_MySQL 慢查询日志

e2543848da0f6b1beea430628cf94b2e.gif

  • 1.定义

  • 2.相关参数

  • 2.开启

  • 3.原因

  • 4.慢查询日志工具mysqldumpslow

1.定义

作用:用来记录在MySQL中响应时间超过阀值的语句。

2.相关参数

mysql> show variables like '%slow_query%';
+---------------------+---------------------------------------+
| Variable_name       | Value                                 |
+---------------------+---------------------------------------+
| slow_query_log      | ON                                    |
| slow_query_log_file | /jssdb/mysql/log/3306/jssdb-query.err |
+---------------------+---------------------------------------+
  • slow_query_log:是否开启慢查询日志,1表示开启,0表示关闭
  • slow_query_log_file:慢查询日志存储路径
mysql> show variables like 'long_query%'; 
+-----------------+-----------+
| Variable_name   | Value     |
+-----------------+-----------+
| long_query_time | 10.000000 |
+-----------------+-----------+
  • long_query_time:慢查询阈值,当查询时间多于设定的阈值时,记录日志
mysql> show variables like 'log_out%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_output    | FILE  |
+---------------+-------+
  • log_output:日志存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。
mysql> show variables like '%using_index%';
+----------------------------------------+-------+
| Variable_name                          | Value |
+----------------------------------------+-------+
| log_queries_not_using_indexes          | ON    |
| log_throttle_queries_not_using_indexes | 10    |
+----------------------------------------+-------+
  • log_queries_not_using_indexes:当ON的时候,没有使用索引就会记录日志信息;当off的时候,表示如果使用了索引,就算慢,也不会记录日志
  • log_throttle_queries_not_using_indexes:设定每分钟记录到日志的未使用索引的语句数目,超过这个数目后只记录语句数量和花费的总时间

2.开启

--修改my.cnf
slow_query_log = ON
slow_query_log_file=/jssdb/mysql/log/3306/jssdb-query.err
long_query_time=10

3.原因

  • 没有索引或者没有用到索引
  • 锁或者死锁
  • 查询出的数据量过大
  • 网络及硬件配置差

4.慢查询日志工具mysqldumpslow

[root@jssdb01 ~]# mysqldumpslow --help
Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]

Parse and summarize the MySQL slow query log. Options are

  --verbose    verbose
  --debug      debug
  --help       write this text to standard output

  -v           verbose
  -d           debug
  -s ORDER     what to sort by (al, at, ar, c, l, r, t), 'at' is default
                al: average lock time
                ar: average rows sent
                at: average query time
                 c: count
                 l: lock time
                 r: rows sent
                 t: query time  
  -r           reverse the sort order (largest last instead of first)
  -t NUM       just show the top n queries
  -a           don't abstract all numbers to N and strings to 'S'
  -n NUM       abstract numbers with at least n digits within names
  -g PATTERN   grep: only consider stmts that include this string
  -h HOSTNAME  hostname of db server for *-slow.log filename (can be wildcard),
               default is '*', i.e. match all
  -i NAME      name of server instance (if using mysql.server startup script)
  -l           don't subtract lock time from total time

举例:

得到返回记录集最多的10个SQL。

mysqldumpslow -s r -t 10 /jssdb/mysql/log/3306/jssdb-query.err

得到访问次数最多的10个SQL

mysqldumpslow -s c -t 10 /jssdb/mysql/log/3306/jssdb-query.err

得到按照时间排序的前10条里面含有左连接的查询语句。

mysqldumpslow -s t -t 10 -g "left join" /jssdb/mysql/log/3306/jssdb-query.err
建议在使用这些命令时结合 | 和more 使用 
mysqldumpslow -s r -t 20 /jssdb/mysql/log/3306/jssdb-query.err | more

a151da0c20d9fc3922159d65252ce4ca.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/311002.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从业务需求抽象成模型解决方案

从业务需求调研,通过抽象转换成模型技术方案,本文将对这个过程做个拆解,供大家参考。以下我所说的可能都是错的,只是一家之见,欢迎大家在留言区多提意见和看法,互相共勉。一、订单对象-信息需求公司的运营都…

《C++ Primer》7.1.4节练习

练习7.11: #include <iostream> #include <cstring> using namespace std;class Sales_data {public:Sales_data() default;Sales_data(const std::string &book): bookNo(book) {}Sales_data(const std::string &book, const unsigned num, const doubl…

DotNetCore Web应用程序中的Session管理

原文来自互联网&#xff0c;由长沙DotNET技术社区编译。如译文侵犯您的署名权或版权&#xff0c;请联系小编&#xff0c;小编将在24小时内删除。限于译者的能力有限&#xff0c;个别语句翻译略显生硬&#xff0c;还请见谅。作者简介&#xff1a;Jon&#xff08;Jonathan&#x…

css3是什么 ptml_CSS3

CSS3HTMLCSSJavaScript结构表项交互如何学习&#xff1f;CSS是什么CSS怎么用(快速入门)CSS选择器(重点难点)美化网页(文字、阴影、超链接、列表、渐变...)盒子模型浮动定位网页动画(特效效果)1、初识CSS1.1、什么是CSSCascading Style Sheet(层叠样式表)CSS&#xff1a;表现(美…

《C++ Primer》7.2节练习

练习7.16: 在类的定义中&#xff0c;可以包含0个或者多个访问说明符&#xff0c;并且对于某个访问说明符能出现多少次以及能出现在哪里都没有严格规定。每个访问说明符指定接下来的成员的访问级别&#xff0c;有效范围直到出现下一个访问说明符或者到达类的结尾为止。 一般来说…

python docx runs_别再问我Python怎么操作Word了!

安装docx是一个非标准库&#xff0c;需要在命令行(终端)中使用pip即可安装pip install python-docx一定要注意&#xff0c;安装的时候是python-docx而实际调用时均为docx!前置知识Word中一般可以结构化成三个部分&#xff1a;文档Document段落Paragraph文字块Run也就是Document…

【要闻】如何基于K8s管理1600个微服务?某数字化银行秘诀公开

Cloud Foundry Foundation宣布KubeCF为新孵化项目Cloud Foundry Foundation是开放源代码项目的聚集地&#xff0c;简化了开发人员的体验&#xff0c;近日其宣布&#xff0c;KubeCF已成为该基金会的孵化项目&#xff0c;并已发布版本1.0.1。KubeCF是Cloud Foundry应用程序运行时…

《C++ Primer》7.2.1节练习

练习7.20: 当非成员函数确实需要访问类的私有成员时&#xff0c;我们可以把它声明成该类的友元。此时&#xff0c;友元可以“工作在类的内部”&#xff0c;像类的成员一样访问类的所有数据和函数。但是一旦使用不慎&#xff08;比如随意设定友元&#xff09;&#xff0c;就有可…

python常用字符串方法调用语法_Python3常用的字符串方法

判断是否全是字母"python".isalpha() # 返回True"2python".isalpha() # 返回False根据分隔符分割字符串a "I,LOVE,PYTHON"a.split(",")# 结果&#xff1a;[I,LOVE,PYTHON]去掉字符串两头的空格及回车符str.strip() # 去掉字符串两边的…

如何用 Blazor 实现 Ant Design 组件库?

本文主要分享我创建 Ant Design of Blazor 项目的心路历程&#xff0c;已经文末有一个 Blazor 线上分享预告。Blazor WebAssembly 来了&#xff01;Blazor 这个新推出的前端 Web 框架&#xff0c;想必是去年 .NET Core 3.0 发布时才进入 .NET 开发者的视线的。但其实&#xff0…

《C++ Primer》7.3.1节练习

练习7.23: class Screen {private:unsigned height 0,width 0;unsigned cursor 0;string contents; }/*对于Screen类来说&#xff0c;必不可少的数据成员有&#xff1a;屏幕的宽度和高度、屏幕的内容以及光标的当前位置*/练习7.24: class Screen {private:unsigned height …

mysql 中如何删除重复的数据_mysql如何快速删除重复的数据

在mysql中去重&#xff0c;其实是一个很简单的事情&#xff0c;来看下面的例子&#xff1a;mysql> DROP TABLE test;Query OK, 0 rows affected (0.01 sec)mysql> CREATE TABLE test(id INT,NAME VARCHAR(10));Query OK, 0 rows affected (0.01 sec)mysql> INSERT IN…

.NET Core开发实战(第28课:工作单元模式(UnitOfWork):管理好你的事务)--学习笔记...

28 | 工作单元模式&#xff08;UnitOfWork&#xff09;&#xff1a;管理好你的事务工作单元模式有如下几个特性&#xff1a;1、使用同一上下文2、跟踪实体的状态3、保障事务一致性我们对实体的操作&#xff0c;最终的状态都是应该如实保存到我们的存储中&#xff0c;进行持久化…

《C++ Primer》7.3.2节练习

练习7.27: #include <iostream> #include <cstring> using namespace std;class Screen {private:unsigned height 0, width 0;unsigned cursor 0;string contents;public:Screen() default;Screen(unsigned ht, unsigned wd): height(ht), width(wd), conten…

【实战 Ids4】║ 控制台密码模式搭配Ocelot网关

&#xff08;此岁只能云赏樱了&#xff09;书接上文&#xff0c;这些天一直在研究IdentityServer4&#xff08;下文简称Ids4&#xff09;框架&#xff0c;发现有很多有意思&#xff0c;或者说比我想象中的知识点&#xff0c;可扩展的多&#xff0c;所以比较开心能钻研进去&…

mysql递归查询 缓存_MySQL-递归查询方法解析

MySQL-递归查询方法解析&#xff0c;兄弟连教育(www.lampbrother.net)帮大家做了个简单的整理&#xff1a;有需要的朋友可以参考下哈。首先表结构和数据CREATE TABLE class ( classid int(11) NOT NULL AUTO_INCREMENT, banji int(11) DEFAULT NULL COMMENT 0, nianji varch…

《C++ Primer》7.3.3节练习

练习7.31: 满足题意的程序如下所示&#xff1a; class X;//声明类型X class Y//定义类型Y {X* x; }; class X//定义类型X {Y y; };类X的声明称为前向声明&#xff0c;它向程序中引入了名字X并且指明X是一种类类型。对于类型X来说&#xff0c;此时我们已知它是一个类类型&#…

.NET Core 如何生成信用卡卡号

点击上方蓝字关注“汪宇杰博客”导语上个月我写了《.NET Core 如何验证信用卡卡号》&#xff0c;不少朋友表示挺有兴趣。在金融科技行业的实际工作中&#xff0c;通常还需要生成信用卡卡号用来测试&#xff0c;今天我就来教大家如何生成信用卡卡号。上回的改进上篇文章写完后&a…

python怎么爬虎牙_使用python爬虫框架scrapy抓取虎牙主播数据

前言本文利用python的scrapy框架对虎牙web端的主播、主播订阅数、主播当前观看人数等基本数据进行抓取&#xff0c;并将抓取到的数据以csv格数输出&#xff0c;以及存储到mongodb中思路观察虎牙网站后确认所有频道url都在www.huya.com/g中的&#xff0c;而主播房间数据则是ajax…

《C++ Primer》7.3.4节练习

练习7.32: 要想让clear函数作为Screen的友元&#xff0c;只需要在Screen类中做出友元声明即可。本题的真正关键之处是程序的组织结构&#xff0c;我们必须首先定义Window_mgr类&#xff0c;其中声明clear函数&#xff0c;但是不能定义它&#xff1b;接下来定义Screen类&#xf…