Mysql——》慢查询日志

news2024/11/25 16:54:50

推荐链接:
    总结——》【Java】
    总结——》【Mysql】
    总结——》【Redis】
    总结——》【Kafka】
    总结——》【Spring】
    总结——》【SpringBoot】
    总结——》【MyBatis、MyBatis-Plus】
    总结——》【Linux】
    总结——》【MongoDB】
    总结——》【Elasticsearch】

Mysql——》慢查询日志

  • 一、慢查询的概念
  • 二、慢查询的原因
  • 三、慢查询的配置
    • 1、是否开启慢查询日志
    • 2、慢查询日志的开启、关闭
    • 3、执行超过多长时间的 SQL记录到慢查询日志
    • 4、没有使用索引的 SQL是否记录到慢查询日志
    • 5、慢查询日志的文件存放路径
  • 三、慢查询的模拟
  • 四、慢查询日志:根据查询时间提取
  • 五、慢查询日志分析:mysqldumpslow工具
    • 1)慢查询日志的文件路径
    • 2)mysqldumpslow的路径
    • 3)mysqldumpslow的参数
    • 4)mysqldumpslow的示例

参考链接:官网Slow Query Log

一、慢查询的概念

慢查询:指查询花费大量时间的查询。
慢查询日志:指mysql记录所有执行超过long_query_time参数设定的时间阈值的SQL语句的日志。

二、慢查询的原因

  • 扫描行数过多
  • 查询不需要的记录
  • 总是取出全部列
  • 重复查询相同的数据

三、慢查询的配置

1、是否开启慢查询日志

-- 是否开启慢查询日志,on开启,off关闭,默认值为off
show variables like 'slow_query_log%';

Q:为什么慢查询日志默认关闭?
A:因为开启慢查询日志是有代价的(跟 bin log、optimizer-trace 一样)

2、慢查询日志的开启、关闭

方式1:动态修改参数(重启后失效)
方式2:修改my.cnf文件(重启后生效)

-- 开启
set @@global.slow_query_log=1; 

-- 关闭
set @@global.slow_query_log=0; 

3、执行超过多长时间的 SQL记录到慢查询日志

-- 查看慢查询时间阈值,默认值为10s
show variables like '%long_query_time%';

-- 设置超过3s的SQL记录到慢日志
set @@global.long_query_time=3;

4、没有使用索引的 SQL是否记录到慢查询日志

-- 是否开启,默认值为off关闭
show VARIABLES like '%log_queries_not_using_indexes%';

-- 开启
set @@global.log_queries_not_using_indexes=1;
-- 关闭
set @@global.log_queries_not_using_indexes=0;

5、慢查询日志的文件存放路径

-- 查看慢查询日志的路径:/data/mysql/data/dcbi-3306/log/slow.log
show variables like 'slow_query_log_file%';

三、慢查询的模拟

-- 方式一
select sleep(10);

-- 方式二
set global long_query_time=0;

四、慢查询日志:根据查询时间提取

cd /data/mysql/data/dcbi-3306/log
sed -n '/2022-10-21T00/,/2020-10-22T00:00/p' slow.log > 20221021.log

五、慢查询日志分析:mysqldumpslow工具

参数链接:官网mysqldumpslow

1)慢查询日志的文件路径

  -- 查看有多少慢查询
 show global status like 'slow_queries';
 
 -- 查看慢查询日志的文件路径:/data/mysql/data/dcbi-3306/log/slow.log
 show variables like 'slow_query_log_file%';

在这里插入图片描述
在这里插入图片描述

2)mysqldumpslow的路径

一般都在Mysql的bin目录下,如:cd /opt/app/install/mysql-5.7.19/bin

3)mysqldumpslow的参数

mysqldumpslow --help
参数参数值描述
-s orderal平均锁定时间
ar平均返回记录数
at平均查询时间(默认)
c计数
l锁定时间
r返回记录
t查询时间
-r返回记录
-t num查询时间,倒序排列,前n条记录
-a只显示前n个查询
-n num
-g pattern
-h hostname
-i name
-l

4)mysqldumpslow的示例

cd /data/mysql/data/dcbi-3306/log


-- 查询用时最多的10条慢sql
mysqldumpslow -s t -t 10 -g 'select' slow.log

-- 查询用时最多,并且包含左连接的的10条慢sql
mysqldumpslow -s t -t 50 -g "left join" slow.log

-- 访问次数最多的10个SQL语句
mysqldumpslow -s c -t 10 slow.log

-- 记录集最多的10个SQL语句
mysqldumpslow -s r -t 10 slow.log

-- 查询用时最多的10条慢sql,并输出到txt
mysqldumpslow -s t -t 10 -g 'select' slow.log > result.txt

-- 查询用时最多的10条慢sql,并输出到csv
mysqldumpslow -s t -t 10 -g 'select' slow.log > result.csv

在这里插入图片描述

Count:代表这个 SQL 执行了多少次
Time:代表执行的时间,括号是累计时间
Lock:表示锁定的时间,括号是累计时间
Rows:表示返回的记录数,括号是累计记录数

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

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

相关文章

TCR中的缓存和共享属性与PTE中的缓存和共享属性的区别是啥?

那么就请继续思考: Translation Table Walk访问页表的缓存策略,这里的页表到底是缓存到cache中,还是缓存到PTW中呢?

使用腾讯云轻量应用服务器搭建网站教程

腾讯云轻量应用服务器怎么搭建网站?太简单了,轻量服务器选择宝塔Linux镜像,然后在宝塔面板上添加站点,以WordPress建站为例,腾讯云服务器网来详细说下腾讯云轻量应用服务器搭建网站全流程,包括轻量服务器配…

【Elasticsearch】ES精确查询和范围查询,ES时间字段排序实例,ES倒排索引介绍

本文ES版本是7.X以上,之前的版本语法可能会有些差异,请注意这些比较重要的细节。问海量数据搜索时为什么ES会比较快? 精确查询 termQuery BoolQueryBuilder boolQuery QueryBuilders.boolQuery();boolQuery.must(QueryBuilders.termQuery(…

ORB-SLAM2学习笔记2之TUM开源数据运行ORB-SLAM2生成轨迹并用evo工具评估轨迹

文章目录 0 引言1 evo工具1.1 简介1.2 常用命令1.3 安装 2 TUM数据3 单目ORB-SLAM23.1 运行ORB-SLAM23.2 evo评估轨迹3.2.1 载入和对比轨迹3.2.2 计算绝对位姿误差 4 RGB-D ORB-SLAM24.1 运行ORB-SLAM24.2 evo评估轨迹4.2.1 载入和对比轨迹4.2.2 计算绝对轨迹误差 ORB-SLAM2学习…

软件工程——第12章面向对象实现知识点整理

本专栏是博主个人笔记,主要目的是利用碎片化的时间来记忆软工知识点,特此声明! 文章目录 1. 面向对象语言技术的特点? 2.选择面向对象程序设计语言时主要应该考虑哪些因素? 3.面向对象设计结果只能用面向对象语言实…

第三方ipad电容笔哪个品牌好用?平板电容笔推荐

可能很多人都认为,苹果原装的电容笔,是不可取代,但我认为,这还要看个人的预算,以及实际的需求。苹果Pencil对于那些不太讲究画质的用户来说实在是太贵了,要是我们仅用于书写上,其实我们可以用平…

尚硅谷Docker实战教程-笔记13【高级篇,Docker轻量级可视化工具Portainer】

尚硅谷大数据技术-教程-学习路线-笔记汇总表【课程资料下载】视频地址:尚硅谷Docker实战教程(docker教程天花板)_哔哩哔哩_bilibili 尚硅谷Docker实战教程-笔记01【基础篇,Docker理念简介、官网介绍、平台入门图解、平台架构图解】…

Python 自学 day01 变量,变量命名规则,一些语法

1. Python 的变量的知识 1.1 Python 编程命令的读取时从上到下的。 1.2 Python 变量的命名规则: 1.2.1变量名只能包含字母、数字和下划线。变量名能以字母或下划线打头,但不能以数字打 头。例如,可将变量命名为message…

BATJ 面试 Java 岗:精选 1200+ 面试题及答案

Z 认为,对于 Java 面试以及进阶的最佳学习方法莫过于刷题博客书籍总结,前三者 LZ 将淋漓尽致地挥毫于这篇文章中,至于总结在于个人,实际上越到后面你会发现面试并不难,其次就是在刷题的过程中有没有去思考,…

网络安全(黑客技术)自学路线笔记

一、什么是黑客? 黑客泛指IT技术主攻渗透窃取攻击技术的电脑高手,现阶段黑客所需要掌握的远远不止这些。 二、为什么要学习黑客技术? 其实,网络信息空间安全已经成为海陆空之外的第四大战场,除了国与国之间的博弈&am…

stm32 mpu6050 cubemx 卡尔曼滤波法读取角度

文章目录 前言一、cubemx配置二、mpu6050文件移植mpu6050.cmpu6050.h 三、主函数 前言 本文简述使用mpu6050读取原始数据后解算出角度。 网上大多都是dmp库来解算,但是这种情况操作起来相对复杂。 更方便的方法是使用卡尔曼滤波法来解算出角度,好处是代…

2023网络安全常见面试题汇总(附答案解析+配套资料)

以下为网络安全各个方向涉及的面试题,星数越多代表问题出现的几率越大,祝各位都能找到满意的工作。 注:所有的资料都整理成了PDF,面试题和答案将会持续更新,因为无论如何也不可能覆盖所有的面试题。 目录 一、渗透测试…

ELK 企业级日志分析系统(三)

ELK 一、Zookeeper理论部分zookeeper的定义与工作机制zookeeper的特点Zookeeper 数据结构Zookeeper 应用场景Zookeeper 选举机制 二、zookeeper部署实验三、Kafka消息队列为什么需要消息队列(MQ)使用消息队列的好处消息队列的两种模式 Kafka 定义Kafka 简…

layui树形菜单的实现

前言 继续上一篇博客的内容,在原来代码的基础上实现树形菜单功能 一. 树形菜单是什么? 在layui中,树形菜单是通过 Tree 组件实现的。Tree 组件提供了一种树形结构展示数据的方式,常用于显示层级结构的菜单、目录等。开发者可以…

虚拟机中安装RabbitMQ及使用(超详细)

目录 1. 安装Socat 2. 安装Erlang 3. 安装RabbitMQ 4. 开启管理界面及配置 5. 启动 6. 配置虚拟主机及用户 6.1. 用户角色 6.2. Virtual Hosts配置 6.2.1. 创建Virtual Hosts 6.2.2. 设置Virtual Hosts权限 1. 安装Socat 在线安装依赖环境: yum install g…

数据结构【二叉树】

数据结构之二叉树 二叉树的定义二叉树的5种基本形态二叉树的抽象类型定义二叉树的特殊类型二叉树的性质二叉树的存储结构1、顺序存储2、链式存储 遍历二叉树前序遍历中序遍历后序遍历遍历算法的分析 线索二叉树 二叉树的定义 在数据结构中,二叉树是n(n&…

uniapp 封装公共方法(无需每个页面引用,直接调用)

封装方法: 1. 在根目录下建立common文件夹 创建com.js 2.在main.js中挂载(写在定义vue之后) import $com from /common/com.js Vue.prototype.$com $com 3.在com.js中按照以下格式定义方法 export default {//定义需要的方法 } 4.使用 click"$com.已经定义的方法名&q…

分布式定时任务xxl-Job

目录 前言 项目介绍 1.源码目录介绍 2 “调度数据库”配置 3 架构设计 3.1 设计思想 5.3.3 架构图 实战 1.服务端部署 2.执行端配置 3.任务开发 3.1 基于方法注解任务 3.2 基于api任务 3.3 分片广播任务 4.任务执行 4.1 单任务执行 4.2 子任务执行 4.3 分片广…

高并发的哲学原理(二)-- Apache 的性能瓶颈与 Nginx 的性能优势

每一名后端开发可能都知道 Nginx 比 Apache 性能强,但是为什么强,强在哪里,接下来我们动手实验解答这个问题。 Nginx 利用了新的 Linux kernel API Nginx 利用了 Linux 内核引入的 epoll 事件驱动 API,大幅降低了海量 TCP 连接下…

IDEA+springboot+ssm+layui+mysql高校宿舍管理系统源码

IDEAspringbootssmlayuimysql高校宿舍管理系统源码 一、系统介绍1.环境配置 二、系统展示1. 管理员登录2.宿舍列表3.预分配宿舍4.宿舍分配信息5. 留校管理6. 报修管理7. 留言管理8.卫生管理9.我的宿舍10.我的报修11.卫生检查记录12.离校登记13.留校申请14.返校登记15.留言板16.…