【MySQL学习】MySQL的慢查询日志和错误日志
꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱
ʕ̯•͡˔•̯᷅ʔ大家好,我是xiaoxie.希望你看完之后,有不足之处请多多谅解,让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客
本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如需转载还请通知˶⍤⃝˶
个人主页:xiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客系列专栏:xiaoxie的MySql学习系列专栏——CSDN博客●'ᴗ'σσணღ
我的目标:"团团等我💪( ◡̀_◡́ ҂)"( ⸝⸝⸝›ᴥ‹⸝⸝⸝ )欢迎各位→点赞👍 + 收藏⭐️ + 留言📝+关注(互三必回)!
一.MySQL的慢查询日志
1.慢查询日志的作用
-
性能诊断与优化:
- 慢查询日志记录了执行时间超过预设阈值的所有SQL查询,这些查询可能成为数据库性能瓶颈的关键因素。
- 通过分析慢查询日志,数据库管理员可以精准地定位到哪些SQL语句执行效率低下,从而针对这些语句进行优化,如改写SQL查询、添加缺失的索引、重构表结构或调整查询策略等。
-
资源消耗监控:
- 长时间运行的查询不仅会影响用户体验,还会占用大量的CPU、内存、I/O资源,可能导致其他查询响应变慢甚至引发阻塞。
- 慢查询日志可以帮助监控系统中消耗资源最多的查询,从而合理分配和管理数据库资源。
-
趋势分析:
- 在一段时间内持续观察慢查询日志,可以发现数据库负载的变化趋势,及时预防潜在的性能问题,并对数据库的工作负载模式有更深入的理解。
-
安全性与合规性:
- 在某些场景下,异常慢的查询可能是由于SQL注入攻击或其他安全事件导致,通过分析慢查询日志可以帮助发现并解决这类问题。
-
自动化工具辅助:
- 结合第三方工具如pt-query-digest(Percona Toolkit的一部分)、mysqldumpslow等,可以自动分析慢查询日志,生成统计报告和优化建议。
总结来说慢查询日志对于我们来说,特别是以后工作的时候,在生产环境下,数据量特别大,可能会达到千万条数据,甚至更多,数据库查询性能至关重要。当数据量达到千万乃至亿级别时,即使是微小的SQL语句效率差异也可能造成显著的性能影响。慢查询日志在这种情况下具有不可忽视的价值,这个时候通过分析慢查询日志,可以帮助我们优化MySQL的性能,保证数据库服务高效稳定运行,理解和熟练运用慢查询日志对于维护大规模数据库系统的性能和稳定性具有直接且重要的意义。
2.如何使用慢查询日志
1.启用慢查询日志
修改MySQL服务器的配置文件(通常为my.cnf或my.ini), 使用文本编辑器(如Notepad++、Sublime Text等)打开配置文件。在[mysqld]部分添加以下行以启用慢查询日志:
slow_query_log = ON # 开启慢查询日志
long_query_time = N # 设置慢查询阈值,单位秒,N为执行时间超过多少秒的SQL将被记录
log_slow_queries = /path/to/slow_query.log # 指定慢查询日志的输出文件路径
# 或者在MySQL 5.5.3之后,使用以下配置代替:
slow_query_log_file = /path/to/slow_query.log
2.配置选项
当配置慢查询日志时,除了基本的启用和设置阈值外,可以设置其他的慢查询日志相关参数,以便更详细地记录慢查询的信息。以下是一些常见的配置选项:
-
记录格式:可以选择不同的记录格式,如verbose模式。在verbose模式下,会记录更多细节信息,如查询的执行计划、锁定信息等。这可以帮助更全面地了解慢查询的执行过程。
-
记录临时表创建:决定是否记录慢查询中创建的临时表的信息。在某些情况下,临时表的创建可能会对性能产生影响,因此记录这些信息可以帮助分析慢查询的原因。
-
记录锁定时间:确定是否记录慢查询中锁定资源的时间信息。当查询导致锁定资源的时间过长时,记录这些信息可以帮助发现潜在的并发问题或者锁等待情况。
这些配置选项可以根据具体需求进行调整,以便更好地了解慢查询的原因和性能瓶颈。通过配置这些参数,可以更详细地记录慢查询日志,为性能优化和故障排查提供更多信息。
3.重启MySQL服务
修改配置后,需要重启MySQL服务,让新的配置生效。
4.查看和分析慢查询日志
使用文本编辑器可以直接查看慢查询日志文件,但由于日志内容通常较为复杂,可以借助专用工具进行分析,如mysqldumpslow工具(随MySQL Server一起安装)
mysqldumpslow [options] /path/to/slow_query.log
mysqldumpslow可以按照不同的排序规则(如按照查询时间、查询次数等)展示日志中的慢查询信息。
mysqldumpslow [options] /path/to/slow_query.log 是一个用于解析和汇总MySQL慢查询日志的命令行工具。具体含义如下:
mysqldumpslow 是MySQL自带的一个工具,它用来读取和分析MySQL服务器产生的慢查询日志文件。
要确切知道慢查询日志文件的位置,请查阅MySQL服务器的配置文件(如/etc/mysql/my.cnf或C:\ProgramData\MySQL\MySQL Server X.X\my.ini),并在其中查找slow_query_log_file这一行,它后面跟着的就是慢查询日志文件的实际路径。
如果你不确定具体路径,可以通过MySQL客户端登录后执行以下命令来查看当前设置的慢查询日志文件路径:
Sql
SHOW VARIABLES LIKE 'slow_query_log_file';
这条SQL语句将返回慢查询日志文件的完整路径。
-
[options]表示可选的命令行参数,用来指定如何过滤和排序日志中的查询。例如:-s <sort_order>:按指定的顺序排序查询,默认是按查询时间排序,可选的排序类型包括:t:查询时间at:平均查询时间l:锁定时间al:平均锁定时间r:查询次数ar:平均每次查询的查询次数
-t <number>:只显示最频繁或最耗时的前N个查询。-v或--verbose:提供更详细的输出信息。-d或--debug:启用调试模式。-h:显示帮助信息。
-
/path/to/slow_query.log是慢查询日志文件的实际路径,mysqldumpslow 将从该文件中读取慢查询记录并进行分析。执行这个命令后,mysqldumpslow 会输出经过排序和汇总后的慢查询信息. - 替换
/path/to/slow_query.log为你实际的慢查询日志文件路径 - 注意
实际的慢查询日志文件路径取决于MySQL服务器的配置。MySQL服务器的慢查询日志文件路径通常在MySQL配置文件(如
my.cnf或my.ini)中设置,配置项为slow_query_log_file。默认情况下,慢查询日志文件的位置可能因MySQL安装和配置的不同而在各种路径下,常见的一些默认路径包括:
- Linux系统上可能的默认是
/var/lib/mysql/hostnameslow.log或/var/log/mysql/mysql-slow.log。 - 也可能是用户自定义的路径,例如
/path/to/slow-query.log。 -
要确切知道慢查询日志文件的位置,请查阅MySQL服务器的配置文件(如
/etc/mysql/my.cnf或C:\ProgramData\MySQL\MySQL Server X.X\my.ini),并在其中查找slow_query_log_file这一行,它后面跟着的就是慢查询日志文件的实际路径。如果你不确定具体路径,可以通过MySQL客户端登录后执行以下命令来查看当前设置的慢查询日志文件路径:
Sql
SHOW VARIABLES LIKE 'slow_query_log_file';这条SQL语句将返回慢查询日志文件的完整路径。
-
例如
-
mysqldumpslow -s t -t 10 /var/log/mysql/slow_query.log这个命令将会显示出日志中执行时间最长的前10个查询。请注意,你需要拥有执行该命令所需的权限,并确保MySQL服务已经运行且开启了慢查询日志功能。
5.优化慢查询
- 根据慢查询日志中的SQL语句和附加信息(如执行计划、锁定时间等),可以着手进行SQL优化,包括但不限于:
- 如果有必要,还可以考虑数据库设计层面的优化。
- 调整查询逻辑,避免复杂关联;
- 改写SQL查询语句,避免全表扫描或不必要的临时表创建;
- 添加或优化索引;
请根据实际版本的MySQL和操作系统环境调整上述步骤,不同版本的MySQL可能有不同的配置项或工具可用。同时,为了不影响线上服务,一般会在非高峰时段开启慢查询日志,并定期对其进行分析处理。
二.MySQL的错误日志
1.错误日志的作用
-
记录错误信息:错误日志记录了MySQL服务器运行过程中发生的错误和警告信息,包括但不限于语法错误、连接失败、权限问题、表损坏、索引错误、内部错误以及其他严重的问题。
-
诊断问题:当MySQL服务器发生故障或不正常行为时,错误日志是首要的排障依据。它记录了错误的详细上下文信息,包括错误的时间、错误号、错误消息以及可能导致错误的操作等,便于程序猿迅速定位问题源头。
-
审计和合规要求:对于一些高安全性和法规遵从性的场景,错误日志可以作为重要的审计记录,跟踪数据库活动中的异常情况,确保符合企业内部和外部监管机构的安全与合规要求。
-
服务器运行状态监控:错误日志还记录了MySQL服务器启动和关闭时的相关信息,包括服务器初始化过程中的状态、配置加载结果以及与其他服务的交互情况。
-
预防性维护:通过定期检查和分析错误日志,程序猿可以预见并防止未来可能出现的问题,比如磁盘空间不足、并发控制引起的死锁、资源竞争等情况。
-
性能问题线索:虽然错误日志主要不是用来追踪性能问题,但在某些情况下,它也可能包含关于资源耗尽、超时等待等间接指向性能瓶颈的线索。
总之,MySQL错误日志是数据库日常运维和故障排除的重要工具,有助于确保数据库系统的稳定运行和有效管理,我们还是需要重点掌握的.
2.如何错误日志
1.配置错误日志
首先,要在MySQL服务器的配置文件(通常是my.cnf或my.ini)中启用并配置错误日志.使用文本编辑器(如Notepad++、Sublime Text等)打开配置文件在[mysqld]部分添加或修改以下配置项:
[mysqld]
log_error = /path/to/error-log-file.err
1.这里/path/to/error-log-file.err是你想要保存错误日志的完整路径和文件名。
2.可以通过log_warnings参数控制是否将警告信息也写入错误日志,设置为log_warnings=1表示记录警告信息
2.重启MySQL服务
修改配置后,需要重启MySQL服务,让新的配置生效。
3.查看错误日志
使用文本编辑器直接打开错误日志文件进行查看,例如:
1less /path/to/error-log-file.err
或者
1tail -f /path/to/error-log-file.err
后者可以实时监控错误日志的增长。
4.分析错误日志
1.错误日志中记录了MySQL服务器启动、运行时遇到的各种错误、警告及关键信息。
2.当MySQL服务无法启动、出现意外停机、查询失败或其他未知问题时,首先要查看错误日志以获取具体的错误信息和堆栈跟踪。
3.根据错误日志中提供的错误编号、错误消息和其他相关信息,可以进一步查阅官方文档或搜索引擎,找到对应的解决方案。
5.管理错误日志大小
针对大型部署,可能还需要设置日志轮转策略,以免单个日志文件过大。这通常通过操作系统级别的日志管理工具或MySQL本身不支持的日志管理插件来实现。
6.调整日志级别
虽然MySQL错误日志主要关注错误和警告,但在某些情况下,也可以通过调整MySQL全局变量(如log_error_verbosity)来改变日志记录的详细程度。
1.log_error_verbosity(从MySQL 5.7.8开始)
这个变量可以设置错误日志的详细级别。默认值为1,即普通模式。将其设置为2,可以得到更详细的错误日志,包括每个线程的堆栈跟踪信息。
SQL
SET GLOBAL log_error_verbosity = 2;
2.log_warnings
控制是否将警告信息写入错误日志。设置为1或更大值时,MySQL将把警告信息记录到错误日志中。
SQL
SET GLOBAL log_warnings = 1;
需要注意的是,更改全局变量可能会影响到整个MySQL服务器的行为,所以在生产环境中应谨慎操作,并结合具体情况权衡日志详细程度和资源消耗之间的平衡。同时,务必保持对错误日志的定期检查和清理,以避免存储空间的过度消耗。
以上就是关于MySQL慢查询日志和错误日志的所有内容,这些内容只是特供一个小模版,具体的业务上的还得具体分析.感谢你的阅读.祝你一天愉快.

相关文章:
【MySQL学习】MySQL的慢查询日志和错误日志
꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好,我是xiaoxie.希望你看完之后,有不足之处请多多谅解,让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN …...
# C++之functional库用法整理
C之functional库用法整理 注:整理一些突然学到的C知识,随时mark一下 例如:忘记的关键字用法,新关键字,新数据结构 C 的function库用法整理 C之functional库用法整理一、functional库的内建仿函数1. 存储和调用函数2. 存…...
查看MySQL版本的方式
文章目录 一、使用cmd输入命令行查看二、在mysql客户端服务器里查询 一、使用cmd输入命令行查看 1、打开 cmd ,输入命令行: mysql --version 2、还是打开cmd,输入命令行:mysql -V (注意了,此时的V是个大写的V) 二、…...
k8s_入门_命令详解
命令详解 kubectl是官方的CLI命令行工具,用于与 apiserver进行通信,将用户在命令行输入的命令,组织并转化为 apiserver能识别的信息,进而实现管理k8s各种资源的一种有效途径 1. 帮助 2. 查看版本信息 3. 查看资源对象等 查看No…...
腾讯、阿里、字节….等大厂都更喜欢什么样的简历?
我985毕业,为什么筛选简历时输给了一个普通一本? 我投了20份简历,为什么没有一个大厂回我? 每次HR收到简历就没下文了,是我的简历有问题吗? 诚然,在求职时,简历往往就是我们给予H…...
OpenHarmony实战:帆移植案例(中)
OpenHarmony实战:帆移植案例(上) Audio服务介绍 服务节点 基于ADM框架的audio驱动对HDI层提供三个服务hdf_audio_render、hdf_audio_capture、hdf_audio_control。 开发板audio驱动服务节点如下: console:/dev # ls -al hdf_au…...
武汉星起航:创始人张振邦智慧领航,孵化伙伴共绘跨境新蓝图!
在风起云涌的跨境电商行业中,武汉星起航电子商务有限公司如同一颗璀璨的明星,引领着众多创业者迈向成功的彼岸。而这一切的背后,都离不开公司创始人张振邦先生的卓越领导与深厚经验。他凭借着在电子商务行业多年的深耕与积累,为武…...
上下收缩、折叠面板
效果: 上下收缩、折叠面板,类似QQ好友列表那种。原理就是在一个布局中,通过button来实现一个独立widget的visible/disable 实现: 1.分组按钮 #ifndef EXPANDPANEL_H #define EXPANDPANEL_H#include <QWidget>class…...
XC7A35T-2FGG484 嵌入式FPGA现场可编程门阵列 Xilinx
XC7A35T-2FGG484 是一款由Xilinx(赛灵思)制造的FPGA(现场可编程门阵列)芯片 以下是XC7A35T-2FGG484 的主要参数: 1. 系列:Artix-7 2. 逻辑单元数量:33280个 3. 工艺技术:28nm 4. …...
淘宝订单API接口:电商业务自动化的新选择
淘宝订单API接口在电商业务自动化中扮演了至关重要的角色。首先,通过API接口,商家可以自动化地查询、创建、修改和删除订单,极大地提高了订单处理效率,减少了人工操作,降低了错误率。其次,商家可以实时获取…...
识典百科词条创建技巧,教你如何轻松创建热门识典百科词条!
网络已经成为人们获取知识和信息的主要途径。在这样一个背景下,识典百科作为一个综合性的网络百科全书,在为读者们提供各种知识的同时,也给广大用户提供了一个创建、编辑和分享知识的平台。如何在识典百科上创建一个高质量的词条,…...
iOS 开发中上传 IPA 文件的方法(无需 Mac 电脑)
引言 在 iOS 开发中,将 IPA 文件上传到苹果开发者中心是一个重要的步骤。通常情况下,我们需要使用 Mac 电脑上的 Xcode 或 Application Loader 工具来完成这个任务。然而,如果你没有 Mac 电脑,也没有关系,本文将介绍一…...
2024-04-08 问AI: 介绍一下AI 大神 吴恩达
文心一言 吴恩达(Andrew Ng)是AI领域的一位重要人物,他的贡献和影响力在学术界、工业界以及在线教育领域都极为显著。 吴恩达出生于1976年,是一位华裔美国人,他在斯坦福大学担任计算机科学系和电子工程系的副教授&am…...
Leetcode面试经典150_Q12整数转罗马数字
题目: 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M …...
Docker-compose部署Alertmanager+Dingtalk+Prometheus+Grafana实现钉钉报警
部署监控 version: 3.7services: #dingtalkdingtalk:image: timonwong/prometheus-webhook-dingtalk:latestcontainer_name: dingtalkrestart: alwayscommand:- --config.file/etc/prometheus-webhook-dingtalk/config.ymlvolumes:- /data/monitor/dingtalk/config.yml:/etc/p…...
算法刷题记录 Day40
算法刷题记录 Day40 Date: 2024.04.06 kamma 56. 多重背包 #include<bits/stdc.h> using namespace std;int main(){int n, c;while(cin>>c>>n){vector<int> weights(n, 0);vector<int> values(n, 0);vector<int> knums(n, 0);for(int …...
Android JNI基础
目录 一、JNI简介1.1 什么是JNI1.2 用途1.3 优点 二、初探JNI2.1 新建cpp\cmake2.2 build.gradle配置2.3 java层配置2.4 cmake和c 三、API详解3.1 JNI API3.1.1 数据类型3.1.2 方法 3.2 CMake脚本 四、再探JNI 一、JNI简介 1.1 什么是JNI JNI(Java Native Interfa…...
裙边挡边带是什么
裙边挡边带:了解其功能与应用 在日常生活和工业生产中,我们经常会遇到各种形状和功能的带子。其中,裙边挡边带是一种特殊类型的带子,它具有独特的结构和功能,被广泛应用于各种场合。本文将介绍裙边挡边带的基本概念、…...
chabot项目介绍
项目介绍 整体的目录如下所示: 上述的项目结构中出了model是必须的外,其他的都可以根据训练的代码参数传入进行调整,有些不需要一定存在data train.pkl:对原始训练语料进行tokenize之后的文件,存储一个list对象,list的每条数据表…...
ChromeOS 中自启动 Fcitx5 和托盘 stalonetray
ChromeOS 更新的飞快,旧文章的方法也老是不好用,找遍了也没找到很好的可以开机自启动 Linux VM 和输入法、托盘的方法。 研究了一下(不,是很久),终于找到个丑陋的实现。 方法基于 ChromeOS 123.0.6312.94…...
终极指南:如何快速完成语雀文档批量导出与迁移
终极指南:如何快速完成语雀文档批量导出与迁移 【免费下载链接】yuque-exporter export yuque to local markdown 项目地址: https://gitcode.com/gh_mirrors/yuq/yuque-exporter 在当今数字化创作时代,语雀文档批量导出已成为许多创作者和团队的…...
定制属于自己的AS-I总线
本公司自己已经完成AS-I总线主站、电源、从站模块的纯国产化,可以基于AS-I总线的基础上进行拓展,欢迎有需求的、有想法的各类人士一起撑起AS-I国产化一片天...
Kotlin 2.4.0 正式发布,快来看看有哪些更新
昨日,JetBrains 发布了 Kotlin 2.4.0-Beta1。 如果你管的是 Android 工具链、Kotlin 多平台,或者团队里已经开始碰 context receivers、注解处理、.klib 兼容问题,这个版本已经值得单独开分支验证。 先说结论 这次最有分量的变化࿰…...
OpenClaw学习助手:Gemma-3-12b-it生成错题本与定制复习计划
OpenClaw学习助手:Gemma-3-12b-it生成错题本与定制复习计划 1. 为什么需要AI学习助手? 作为一名经常需要处理大量学习资料的开发者,我一直在寻找能够提升学习效率的工具。传统的错题本整理方式需要手动抄写题目、标注知识点、寻找同类练习题…...
从‘迷失’到‘秒达’:我用PyCharm的‘符号搜索’和‘调用链查看’重构了老项目
从‘迷失’到‘秒达’:我用PyCharm的‘符号搜索’和‘调用链查看’重构了老项目 接手一个缺乏文档的遗留代码库,就像被扔进一座没有地图的迷宫。上周我面对的就是这样一个Python项目——3万行代码,零文档,函数命名随意得像临时起意…...
告别重复造轮子:用快马AI一键生成无名小站高效开发模板
作为一个经常需要快速搭建小型网站的后端开发者,我最近发现了一个能极大提升开发效率的方法——用InsCode(快马)平台的AI生成功能来创建可复用的基础模块代码。今天就以"无名小站"的后台管理系统为例,分享我的实践心得。 为什么需要代码生成工…...
告别教材下载烦恼:国家中小学智慧教育平台电子课本解析工具如何实现3分钟高效获取
告别教材下载烦恼:国家中小学智慧教育平台电子课本解析工具如何实现3分钟高效获取 【免费下载链接】tchMaterial-parser 国家中小学智慧教育平台 电子课本下载工具,帮助您从智慧教育平台中获取电子课本的 PDF 文件网址并进行下载,让您更方便地…...
别再死记硬背了!用C++/Java手把手实现线索二叉树(附完整代码与避坑指南)
从零实现线索二叉树:C/Java双语言实战与陷阱全解析 第一次在面试白板上遇到线索二叉树的实现题时,我的手心全是汗。教科书上的递归图示看起来清晰,但真正要写出无bug的线索化代码时,那些ltag和rtag就像捉迷藏的孩子,总…...
大模型RL算法梳理:从全量词元到部分词元的路径演化
一、 引言:大模型强化学习算法的演化格局 近年来,以 OpenAI 的 o1 系列、DeepSeek 的 R1,以及 Qwen 系列模型为代表,大语言模型在数学证明、代码生成等长链路推理任务中展现出更强的稳定性与推理深度。 在这一背景下,面…...
AI 视频生成美女跳舞测评 | 顶级 Prompt实测版(Grok Imagine、Kling AI 3.0、Veo 3.1)
兄弟们,AI 视频生成已经卷到飞起了!之前写小黄文靠grok,现在生成“美女舞蹈”视频也得靠它。 今天上手实测截至今天热门的3款视频生成工具,专攻“美女跳舞”这个高难度场景:动作流畅度、人物一致性、性感画面感、提示…...
