news 2026/6/9 22:38:26

MySQL 的日志体系

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL 的日志体系

MySQL 的日志体系主要分为服务器层日志(所有存储引擎通用)和存储引擎层日志(如 InnoDB 专属)两大类,不同日志承担不同的功能(如故障排查、性能优化、数据恢复、主从复制等)。以下是核心日志类型的详细说明:

一、服务器层核心日志(通用日志)

1. 错误日志(Error Log)
  • 核心作用:记录 MySQL 服务器启动、运行、停止过程中的所有错误、警告、通知类信息(如启动失败、连接异常、权限错误、磁盘满等),是排查 MySQL 基础故障的首要日志。
  • 关键配置
    • log_error:指定错误日志的存储路径(默认开启,无法关闭);
    • log_warnings:控制警告信息是否写入(默认开启)。
  • 文件命名:默认名为hostname.err(如localhost.err),路径通常在 MySQL 数据目录下。
2. 二进制日志(Binary Log,简称 Binlog)
  • 核心作用:记录所有修改数据的操作(增删改 DML、DDL 语句,不含只读查询如 SELECT),是 MySQL 最核心的日志之一,主要用于:
    • 主从复制(主库将 binlog 发送给从库,从库重放实现数据同步);
    • 数据恢复(通过mysqlbinlog解析 binlog,重放操作恢复数据)。
  • 关键特性
    • 格式:支持 3 种(STATEMENT记录 SQL 语句、ROW记录行变更、MIXED混合模式,推荐ROW);
    • 配置:log_bin开启 binlog(MySQL 8.0 若启用 GTID 则默认开启),expire_logs_days自动清理过期 binlog;
    • 文件命名:mysql-bin.000001mysql-bin.000002(按序号递增),配合mysql-bin.index索引文件管理。
3. 慢查询日志(Slow Query Log)
  • 核心作用:记录执行时间超过阈值(long_query_time)的 SQL 语句,是性能优化的核心工具(定位慢 SQL、优化索引 / 语句)。
  • 关键配置
    • slow_query_log:是否开启(默认关闭);
    • long_query_time:慢查询阈值(默认 10 秒,支持小数如 0.5 秒);
    • log_queries_not_using_indexes:记录未使用索引的查询(即使执行时间未达阈值);
    • slow_query_log_file:指定日志文件路径。
  • 辅助工具:可通过pt-query-digest解析慢查询日志,快速定位高频慢 SQL。
4. 通用查询日志(General Query Log)
  • 核心作用:记录所有客户端的连接请求执行的所有 SQL 语句(包括只读查询),用于调试(如定位谁执行了某条 SQL、排查异常连接)。
  • 注意事项:默认关闭,开启后会产生大量日志(IO 压力大),生产环境仅临时开启调试。
  • 关键配置general_log开启,general_log_file指定日志路径。
5. 数据定义语言日志(DDL Log,MySQL 8.0 新增)
  • 核心作用:记录 DDL 操作的元数据变更过程,用于 DDL 操作崩溃后的恢复(如创建表时数据库宕机,重启后通过 DDL 日志完成剩余操作)。
  • 特性:默认开启,无法关闭,日志文件名为ddl_log.log(数据目录下),文件大小限制为 4GB,自动轮转。

二、存储引擎层日志(以 InnoDB 为例)

1. 重做日志(Redo Log)
  • 核心作用:InnoDB 专属,记录数据页的物理变更(如页号、偏移量、修改后的值),保证崩溃恢复(Crash Recovery)
    • MySQL 宕机时,未刷盘的脏页(内存中修改但未写入磁盘的数据)可通过 Redo Log 恢复,避免数据丢失;
    • 采用 “预写式日志(WAL)”:先写 Redo Log,再刷磁盘数据,提升性能。
  • 关键配置
    • innodb_log_file_size:单个 Redo Log 文件大小(推荐 1-4GB);
    • innodb_log_files_in_group:Redo Log 文件组数(默认 2 个,如ib_logfile0ib_logfile1);
    • 特性:循环写(写满一组后覆盖旧文件),存储在数据目录下。
2. 回滚日志(Undo Log)
  • 核心作用:InnoDB 专属,主要用于:
    • 事务回滚:记录事务修改前的数据状态,事务执行失败时回滚到原始状态;
    • MVCC(多版本并发控制):为读提交、可重复读隔离级别提供快照读,避免幻读 / 不可重复读。
  • 特性
    • 逻辑日志(记录 “反向操作”,如 INSERT 对应 DELETE,UPDATE 对应反向 UPDATE);
    • MySQL 8.0 前默认存储在共享表空间ibdata1,8.0 可独立存储在undo_001undo_002文件,支持自动清理。

三、辅助日志(主从复制专属)

中继日志(Relay Log)
  • 核心作用:从库专属,主库的 binlog 传输到从库后,先写入中继日志,从库的 SQL 线程再读取中继日志并重放,实现主从同步。
  • 特性
    • 格式与 binlog 完全一致,文件名为relay-bin.000001relay-bin.000002
    • 从库同步完成后,中继日志会被自动清理(可通过relay_log_purge控制);
    • 若从库宕机,中继日志损坏可能导致同步中断,需重新同步或修复。

总结:核心日志用途速查

日志类型核心用途开启状态
错误日志排查启动 / 运行故障默认开启(必开)
二进制日志主从复制、数据恢复8.0 默认开启
慢查询日志性能优化(定位慢 SQL)默认关闭
通用查询日志调试(记录所有 SQL / 连接)默认关闭
Redo LogInnoDB 崩溃恢复强制开启
Undo Log事务回滚、MVCC强制开启
中继日志从库同步主库数据主从复制时自动开
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 18:35:12

【GRPC 和 HTTP】设计目标和底层实现

文章目录一、核心维度对比表二、关键差异拆解1. 序列化:JSON vs Protobuf(性能核心差距)2. 传输协议:HTTP/1.1 vs HTTP/2(并发能力差距)3. 通信模式:单向请求 vs 多模式流式4. 接口契约&#xf…

作者头像 李华
网站建设 2026/6/9 15:45:00

littlefs v2到v3版本升级:10大关键技术特性深度解析

littlefs v2到v3版本升级:10大关键技术特性深度解析 【免费下载链接】littlefs A little fail-safe filesystem designed for microcontrollers 项目地址: https://gitcode.com/GitHub_Trending/li/littlefs littlefs是一个专为微控制器设计的轻量级故障安全…

作者头像 李华
网站建设 2026/6/8 12:51:50

macOS iSCSI Initiator终极指南:免费扩展存储空间的完整方案

macOS iSCSI Initiator终极指南:免费扩展存储空间的完整方案 【免费下载链接】iSCSIInitiator iSCSI Initiator for macOS 项目地址: https://gitcode.com/gh_mirrors/is/iSCSIInitiator 还在为MacBook存储空间不足而烦恼吗?macOS iSCSI Initiato…

作者头像 李华
网站建设 2026/6/8 6:41:15

pcb-tools终极指南:5步搞定PCB文件可视化

pcb-tools终极指南:5步搞定PCB文件可视化 【免费下载链接】pcb-tools Tools to work with PCB data (Gerber, Excellon, NC files) using Python. 项目地址: https://gitcode.com/gh_mirrors/pc/pcb-tools PCB设计新手面对Gerber、Excellon等专业制造文件时&…

作者头像 李华
网站建设 2026/6/9 5:41:59

终极指南:用macOS iSCSI Initiator免费扩展Mac存储空间的完整教程

终极指南:用macOS iSCSI Initiator免费扩展Mac存储空间的完整教程 【免费下载链接】iSCSIInitiator iSCSI Initiator for macOS 项目地址: https://gitcode.com/gh_mirrors/is/iSCSIInitiator 还在为MacBook存储空间不足而烦恼吗?macOS iSCSI Ini…

作者头像 李华