盘点MySQL的八大日志,你知道哪些?

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 盘点MySQL的八大日志,你知道哪些?

前言


日志对于任何系统应用来说都承载着至关重要的作用,借助日志,我们可以发现系统运行错误的原因,从而解决问题。MySQL也不例外,也会记录各种各样的日志信息。那么你知道MySQL都有哪些日志吗?每种日志的作用是干吗吗?


1671200817071.jpg


redo log日志


介绍

重做日志(redo log)是InnoDB存储引擎生成的日志,记录的是"物理级别"上的页修改操作,比如页号xxx,偏移量yyy写入了'zzz'数据。

作用

  • 用于事务提交时保证事务的持久性,保证数据的可靠性

查看日志

通过执行show global variables like 'innodb_log%';命令查看redo log相关的配置

1671200827525.jpg

  • innodb_log_group_home_dir:指定 redo log 文件组所在的路径,默认值为 ./, 默认以ib_logfile0,ib_logfile1名称存在
  • innodb_log_files_in_group:指明redo log file的个数

关于redo log的详情查看 详解MySQL事务日志——redo log


undo log日志


介绍

回滚日志(undo log)是InnoDB存储引擎生成的日志,记录的是 逻辑操作 日志,比如对某一行数据进行了INSERT语句操作,那么undo log就记录一条与之相反的DELETE操作。

作用

  • 用于事务的回滚,用来保证事务的原子性、一致性。
  • 回滚行记录到某种特定的版本——MVCC,对事务的隔离性起到辅助作用。

查看日志

通过命令show variables like 'innodb_undo%';查看undo log相关的配置。

1671200843858.jpg

  • innodb_undo_directory:指定 undo log 文件组所在的路径,默认值为 ./, 文件名默认为ibdata1

关于undo log的详情查看 详解MySQL事务日志——undo log


bin log日志


介绍

二进制日志bin log可以说是MySQL中比较重要的日志了,在日常开发及运维过程中,经常会遇到。

binlog也叫作变更日志(update log)。它记录了数据库所有执行的 DDLDML 等数据库更新事件的语句,但是不包含没有修改任何数据的语句(如数据查询语句selectshow等)

作用

  • 一是用于数据恢复,如果MySQL数据库意外停止,可以通过二进制日志文件来查看用户执行了哪些操作,对数据库服务器文件做了哪些修改,然后根据二进制日志文件中的记录来恢复数据库服务器。
  • 二是用于数据复制,由于日志的延续性和时效性,master把它的二进制日志传递给slaves来达到master-slave数jie据一致的目的。

查看日志

通过命令show variables like '%log_bin%';查看bin log相关的配置。

1671200856263.jpg

  • log_bin_basename: 是bin log日志的基本文件名,后面会追加标识来表示每一个文件
  • log_bin_index: 是binlog文件的索引文件,这个文件管理了所有的binlog文件的目录

关于bin log的详情查看详解MySQL非常重要的日志—bin log


慢查询日志


介绍

MySQL的慢询日志,提供了记录在MySQL中响应时间超过指定阈值语句的功能,比如设定阈值为3秒,那么任何SQL执行超过3秒都会被记录下来。

作用

  • 统一记录慢的SQL, 有针对性的进行性能优化, 高系统的整体效率

查看日志

通过show variables like '%slow_query_log';命令查看慢SQL相关的配置,如下图:

1671200871013.jpg

关于慢查询日志的详情使用查看 你的哪些SQL慢?看看MySQL慢查询日志吧


错误日志


介绍

错误日志记录了MySQL服务器启动、停止运行的时间,以及系统启动、运行和停止过程中的诊断信息,包括错误、警告和提示等。

作用

  • 查看系统的运行状态,便于即时发现故障、修复故障。
  • 用于排查MySQL服务出现异常的原因。

查看日志

通过命令SHOW VARIABLES LIKE 'log_err%';查看错误日志的位置和配置信息。

1671200888766.jpg

  • log_error的值就是错误日志的位路径

在MySQL故障的情况下,打开错误文件,然后搜索Error、Waiting级别的日志记录,然后参考诊断信息即可。


通用查询日志


介绍

通用查询日志记录用户的所有操作,包括启动和关闭MySQL服务、所有用户的连接开始时间和截止时间、发给 MySQL 数据库服务器的所有 SQL 指令等,如selectshow等,无论SQL的语法正确还是错误、也无论SQL执行成功还是失败,MySQL都会将其记录下来。

作用

  • 还原操作时的具体场景,用于帮助我们准确定位一些疑难问题

查看日志

通过命令SHOW VARIABLES LIKE '%general%';查看通用日志的状态。

1671200898341.jpg

  • general_log: 通用查询日志默认处于关闭状态,因为开启会消耗系统资源并且占用磁盘空间,可以通过SET GLOBAL general_log=on;命令打开
  • general_log_file:通用查询日志记录的位置

我们可以在项目测试阶段,开启查询日志,分析日志中SQL的平均耗时,在生产环境建议不开启。


中继日志


介绍

中继日志(relay log)是MySQL 8中引入的,只在主从服务器架构的从服务器上存在。从服务器为了与主服务器保持一致,要从主服务器读取二进制日志的内容,并且把读取到的信息写入本地的日志文件中,这个从服务器本地的日志文件就叫中继日志 。

作用

  • 用于主从数据同步,从服务器从中继日志中读取内容,恢复数据

查看日志

中继日志的结构和bin log一样,同样存在一个xx-relaybin.index索引文件,以及多个xx-relaybin.00001xx-relaybin.00002....数据文件。


数据定义语句日志


介绍

数据定义语句日志(ddl.log)记录数据定义语句执行的元数据操作,例如DROP TABLEALTER TABLE等。

作用

  • MySQL使用此日志从元数据操作中间发生的崩溃中恢复。

查看日志

这是一个二进制文件,目的也不是给用户查看使用,不重点讲了。


总结


本文讲解了MySQL中出现的8种日志,其中redo logundo logbin log、慢查询日志以及错误日志是比较重要的几个日志,需要我们对他们有比较深入的认识和理解。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
27天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
131 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
22天前
|
关系型数据库 MySQL 数据库
【赵渝强老师】MySQL的binlog日志文件
MySQL的binlog日志记录了所有对数据库的更改操作(不包括SELECT和SHOW),主要用于主从复制和数据恢复。binlog有三种模式,可通过设置binlog_format参数选择。示例展示了如何启用binlog、设置格式、查看日志文件及记录的信息。
|
2月前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1673 14
|
23天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL的撤销日志文件和错误日志文件
本文介绍了MySQL的物理存储结构,重点讲解了InnoDB存储引擎中的撤销日志文件(undo log)和错误日志文件。从MySQL 8.0开始,默认生成两个10MB的undo表空间文件,并支持动态扩容和收缩。错误日志文件记录了MySQL启动、运行、关闭过程中的问题,通过示例展示了如何查看和使用这些日志。
|
2月前
|
SQL 存储 关系型数据库
Mysql主从同步 清理二进制日志的技巧
Mysql主从同步 清理二进制日志的技巧
31 1
|
2月前
|
关系型数据库 MySQL 数据库
DZ社区 mysql日志清理 Discuz! X3.5数据库可以做定期常规清理的表
很多站长在网站日常维护中忽略了比较重要的一个环节,就是对于数据库的清理工作,造成数据库使用量增加必须多的原因一般有2个:后台站点功能开启了家园,此功能现在很少有论坛会用到,但是灌水机会灌入大量垃圾信息致使站长长时间未能发觉;再有就是程序默认的一些通知类表单会存放大量的、对于网站日常运行并无意义的通知信息。
95 2
|
2月前
|
存储 关系型数据库 MySQL
MySQL中的Redo Log、Undo Log和Binlog:深入解析
【10月更文挑战第21天】在数据库管理系统中,日志是保障数据一致性和完整性的关键机制。MySQL作为一种广泛使用的关系型数据库管理系统,提供了多种日志类型来满足不同的需求。本文将详细介绍MySQL中的Redo Log、Undo Log和Binlog,从背景、业务场景、功能、底层实现原理、使用措施等方面进行详细分析,并通过Java代码示例展示如何与这些日志进行交互。
146 0
|
4月前
|
API C# 开发框架
WPF与Web服务集成大揭秘:手把手教你调用RESTful API,客户端与服务器端优劣对比全解析!
【8月更文挑战第31天】在现代软件开发中,WPF 和 Web 服务各具特色。WPF 以其出色的界面展示能力受到欢迎,而 Web 服务则凭借跨平台和易维护性在互联网应用中占有一席之地。本文探讨了 WPF 如何通过 HttpClient 类调用 RESTful API,并展示了基于 ASP.NET Core 的 Web 服务如何实现同样的功能。通过对比分析,揭示了两者各自的优缺点:WPF 客户端直接处理数据,减轻服务器负担,但需处理网络异常;Web 服务则能利用服务器端功能如缓存和权限验证,但可能增加服务器负载。希望本文能帮助开发者根据具体需求选择合适的技术方案。
188 0
|
1月前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
212 30
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
2月前
|
XML JSON Java
Logback 与 log4j2 性能对比:谁才是日志框架的性能王者?
【10月更文挑战第5天】在Java开发中,日志框架是不可或缺的工具,它们帮助我们记录系统运行时的信息、警告和错误,对于开发人员来说至关重要。在众多日志框架中,Logback和log4j2以其卓越的性能和丰富的功能脱颖而出,成为开发者们的首选。本文将深入探讨Logback与log4j2在性能方面的对比,通过详细的分析和实例,帮助大家理解两者之间的性能差异,以便在实际项目中做出更明智的选择。
271 3