当前位置: 首页 > article >正文

深入理解MySQL日志机制

目录

1. MySQL日志概述

2. 错误日志(Error Log)

2.1 错误日志的作用

2.2 错误日志的配置

2.3 查看错误日志

3. 二进制日志(Binary Log)

3.1 二进制日志的作用

3.2 二进制日志的配置

3.3 查看二进制日志

3.4 二进制日志的格式

4. 查询日志(General Query Log)

4.1 查询日志的作用

4.2 查询日志的配置

4.3 查看查询日志

5. 慢查询日志(Slow Query Log)

5.1 慢查询日志的作用

5.2 慢查询日志的配置

5.3 查看慢查询日志

6. 事务日志(Transaction Log)

6.1 Redo Log

6.1.1 Redo Log的作用

6.1.2 Redo Log的配置

6.2 Undo Log

6.2.1 Undo Log的作用

6.2.2 Undo Log的配置

7. 中继日志(Relay Log)

7.1 中继日志的作用

7.2 中继日志的配置

7.3 查看中继日志

8. 日志的管理与维护

8.1 日志的清理

8.2 日志的备份

9. 总结


MySQL的日志系统是数据库管理的重要组成部分,它记录了数据库的各种操作和状态信息,帮助管理员进行故障排查、性能优化和数据恢复。本文将深入探讨MySQL中的各种日志类型,包括错误日志二进制日志查询日志慢查询日志事务日志(Redo Log 和 Undo Log)以及中继日志,并详细介绍它们的作用、配置和使用方法。


1. MySQL日志概述

MySQL的日志系统分为多种类型,每种日志都有其特定的用途:

  • 错误日志(Error Log):记录MySQL服务器运行过程中的错误信息。

  • 二进制日志(Binary Log):记录所有对数据库的修改操作,用于数据恢复和主从复制。

  • 查询日志(General Query Log):记录所有执行的SQL语句。

  • 慢查询日志(Slow Query Log):记录执行时间超过指定阈值的SQL语句。

  • 事务日志(Transaction Log):包括Redo Log和Undo Log,用于保证事务的原子性和持久性。

  • 中继日志(Relay Log):在主从复制中,从服务器用于存储从主服务器接收到的二进制日志事件。


2. 错误日志(Error Log)

错误日志记录了MySQL服务器运行过程中发生的错误、警告和通知信息。它是排查数据库问题的重要工具。

2.1 错误日志的作用

  • 记录MySQL启动、运行和关闭过程中的错误信息。

  • 记录InnoDB存储引擎的故障信息。

  • 记录复制过程中的错误信息。

2.2 错误日志的配置

在MySQL配置文件(my.cnfmy.ini)中,可以通过以下参数配置错误日志:

[mysqld]
log_error = /var/log/mysql/error.log

2.3 查看错误日志

可以通过以下命令查看错误日志的内容:

tail -f /var/log/mysql/error.log

3. 二进制日志(Binary Log)

二进制日志记录了所有对数据库的修改操作(如INSERTUPDATEDELETE等),但不包括SELECT操作。二进制日志主要用于数据恢复和主从复制。

3.1 二进制日志的作用

  • 数据恢复:通过二进制日志可以恢复到某个时间点的数据状态。

  • 主从复制:主服务器将二进制日志发送给从服务器,从服务器重放这些日志以实现数据同步。

3.2 二进制日志的配置

在MySQL配置文件中,可以通过以下参数启用和配置二进制日志:

[mysqld]
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 7
max_binlog_size = 100M

3.3 查看二进制日志

可以使用mysqlbinlog工具查看二进制日志的内容:

mysqlbinlog /var/log/mysql/mysql-bin.000001

3.4 二进制日志的格式

MySQL支持三种二进制日志格式:

  • STATEMENT:记录SQL语句。

  • ROW:记录每一行的修改。

  • MIXED:结合STATEMENT和ROW格式。

可以通过以下命令查看和设置二进制日志格式:

SHOW VARIABLES LIKE 'binlog_format';
SET GLOBAL binlog_format = 'ROW';

4. 查询日志(General Query Log)

查询日志记录了所有执行的SQL语句,包括SELECTSHOW操作。查询日志通常用于调试和审计。

4.1 查询日志的作用

  • 记录所有客户端执行的SQL语句。

  • 用于调试和性能分析。

4.2 查询日志的配置

在MySQL配置文件中,可以通过以下参数启用和配置查询日志:

[mysqld]
general_log = 1
general_log_file = /var/log/mysql/query.log

4.3 查看查询日志

可以通过以下命令查看查询日志的内容:

tail -f /var/log/mysql/query.log

5. 慢查询日志(Slow Query Log)

慢查询日志记录了执行时间超过指定阈值的SQL语句,用于分析和优化查询性能。

5.1 慢查询日志的作用

  • 记录执行时间超过long_query_time的SQL语句。

  • 用于优化查询性能。

5.2 慢查询日志的配置

在MySQL配置文件中,可以通过以下参数启用和配置慢查询日志:

[mysqld]
slow_query_log = 1
slow_query_log_file = /var/log/mysql/slow.log
long_query_time = 2

5.3 查看慢查询日志

可以通过以下命令查看慢查询日志的内容:

tail -f /var/log/mysql/slow.log

6. 事务日志(Transaction Log)

事务日志包括Redo LogUndo Log,用于保证事务的原子性和持久性。

6.1 Redo Log

Redo Log记录了事务对数据的修改操作,用于崩溃恢复。

6.1.1 Redo Log的作用
  • 保证事务的持久性。

  • 在崩溃恢复时重放未提交的事务。

6.1.2 Redo Log的配置

在MySQL配置文件中,可以通过以下参数配置Redo Log:

[mysqld]
innodb_log_file_size = 100M
innodb_log_files_in_group = 2

6.2 Undo Log

Undo Log记录了事务修改前的数据状态,用于事务回滚和MVCC(多版本并发控制)。

6.2.1 Undo Log的作用
  • 支持事务回滚。

  • 实现MVCC,提供一致性视图。

6.2.2 Undo Log的配置

在MySQL配置文件中,可以通过以下参数配置Undo Log:

[mysqld]
innodb_undo_directory = /var/lib/mysql/undo
innodb_undo_tablespaces = 2

7. 中继日志(Relay Log)

中继日志用于主从复制,从服务器将主服务器的二进制日志事件存储在中继日志中,然后重放这些事件以实现数据同步。

7.1 中继日志的作用

  • 存储从主服务器接收到的二进制日志事件。

  • 支持主从复制的数据同步。

7.2 中继日志的配置

在MySQL配置文件中,可以通过以下参数配置中继日志:

[mysqld]
relay_log = /var/log/mysql/relay.log
relay_log_index = /var/log/mysql/relay-log.index

7.3 查看中继日志

可以使用mysqlbinlog工具查看中继日志的内容:

mysqlbinlog /var/log/mysql/relay.000001

8. 日志的管理与维护

8.1 日志的清理

  • 定期清理过期的日志文件,避免占用过多磁盘空间。

  • 使用PURGE BINARY LOGS命令清理二进制日志:

PURGE BINARY LOGS TO 'mysql-bin.000003';

8.2 日志的备份

  • 定期备份重要的日志文件,如二进制日志和事务日志。

  • 使用FLUSH LOGS命令刷新日志文件:

FLUSH LOGS;

9. 总结

MySQL的日志系统是数据库管理的重要组成部分,每种日志都有其特定的用途。通过合理配置和管理日志,可以提高数据库的可靠性、可维护性和性能。希望本文能帮助你深入理解MySQL的日志机制,并在实际工作中灵活运用。

相关文章:

深入理解MySQL日志机制

目录 1. MySQL日志概述 2. 错误日志(Error Log) 2.1 错误日志的作用 2.2 错误日志的配置 2.3 查看错误日志 3. 二进制日志(Binary Log) 3.1 二进制日志的作用 3.2 二进制日志的配置 3.3 查看二进制日志 3.4 二进制日志的…...

Sql Server 索引性能优化 分析以及分表

定位需优化语句 根据工具 skywking 或者开启慢查询日志 找到 慢sql 的语句根据 执行过程 来 判断 慢的原因 row filter 指标 看查了多少数据 比例多少 type 看下是单表 还是 join联表 比如 执行步骤多 没索引 优化方向 减少执行次数索引 没索引考虑加索引 加索引 尽量选择 i…...

vue使用element-ui自定义样式思路分享【实操】

前言 在使用第三方组件时,有时候组件提供的默认样式不满足我们的实际需求,需要对默认样式进行调整,这就需要用到样式穿透。本篇文章以vue3使用element-ui的Tabs组件,对Tabs组件的添加按钮样式进行客制化为例。 确定需要修改的组…...

2020年全国职业院校技能大赛改革试点赛高职组“云计算”竞赛赛卷第二场次题目:容器云平台部署与运维

2020年全国职业院校技能大赛改革试点赛高职组 “云计算”竞赛赛卷 第二场次题目:容器云平台部署与运维 说明:本任务提供有2台服务器master和node,都安装了centos7.5操作系统,在/opt/centos目录下有CentOS-7-x86_64-DVD-1804系统光盘文件所有文件,在/opt/containerk8s目…...

PowerBI 条形图,解决数据标签在条形内部看不清的问题

比如下面的条形图: 最上面两行,数据标签显示在了条形内部,哪怕设置了值为黑色 字体也会自动切换为白色,如果设计要求条形的颜色是浅色,就会导致数据看不清晰。 解决方法一: 将数据标签位置设置为端外 效果…...

下载与快速上手 NVM:Node.js 版本管理工具

一、准备工作:卸载旧版 Node.js 重要提示:在安装 NVM 前,请先彻底删除已安装的 Node.js,避免路径冲突: 检查安装路径 bash where node常见路径: C:\Program Files\nodejs\C:\Users\用户名\AppData\Local\n…...

网络防火墙(Firewall)、Web防火墙(WAF)、入侵检测系统(IDS)、入侵防御系统(IPS)对比总结

目录 一、Firewall、WAF、IDS、IPS四种设备简介 二、Firewall、WAF、IDS、IPS四种设备的角色定位 三、防火墙(Firewall)与入侵检测系统(IPS)的区别 四、入侵检测系统(IDS)与入侵防御系统(IP…...

Unity | 游戏数据配置

目录 一、ScriptableObject 1.创建ScriptableObject 2.创建asset资源 3.asset资源的读取与保存 二、Excel转JSON 1.Excel格式 2.导表工具 (1)处理A格式Excel (2)处理B格式Excel 三、解析Json文件 1.读取test.json文件 四、相关插件 在游戏开发中,策划…...

IT工具 | node.js 进程管理工具 PM2 大升级!支持 Bun.js

P(rocess)M(anager)2 是一个 node.js 下的进程管理器,内置负载均衡,支持应用自动重启,常用于生产环境运行 node.js 应用,非常好用👍 🌼概述 2025-03-15日,PM2发布最新版本v6.0.5,这…...

VulnHub-Web-Machine-N7通关攻略

一、信息收集 第一步:确定靶机IP为192.168.0.107 第二步:扫描后台及开放端口 第三步:进行敏感目录及文件扫描 http://192.168.0.107/index.html (CODE:200|SIZE:1620) http://192.168.0.107/server-status (CODE:403|SIZ…...

发现一个好用的Vue.js内置组件

目录 一、这个好用的内置组件是什么&#xff1f; 二、这个组件的主要功能 三、怎么使用&#xff1f; 四、使用注意事项 五、我的使用场景 一、这个好用的内置组件是什么&#xff1f; 今天在优化我的平台应用时&#xff0c;发现一个好用的组件标签--<keep-alive>。 …...

论华为 Pura X 折叠屏性能检测

在科技浪潮中&#xff0c;折叠屏手机以其创新形态掀起市场热潮。华为 Pura X 作为华为最新折叠手机&#xff0c;承载前沿科技与精湛工艺&#xff0c;成为行业焦点。它融合先进折叠屏技术与优质材质&#xff0c;致力于打破传统手机使用边界&#xff0c;为用户开启全新体验。但产…...

生成PDF文件:从html2canvas和jsPdf渲染到Puppeteer矢量图

刚刚实现而已&#xff1a;第一次明白&#xff0c;双击或file:///打开html文件&#xff0c;居然和从localhost:3000打开同一个html文件有本质的区别。 字体居然还能以Base64代码嵌入到网页&#xff0c;只是太大太笨。 需要安装node.js&#xff0c;npm安装更多依赖&#xff1a;…...

在 Elasticsearch 中探索基于 NVIDIA 的 GPU 加速向量搜索

作者&#xff1a;来自 Elastic Chris Hegarty 及 Hemant Malik 由 NVIDIA cuVS 提供支持&#xff0c;此次合作旨在为开发者在 Elasticsearch 中的向量搜索提供 GPU 加速。 在 Elastic Engineering 组织内&#xff0c;我们一直致力于优化向量数据库的性能。我们的使命是让 Lucen…...

Junit在测试过程中的使用方式,具体使用在项目测试中的重点说明

JUnit 是一个广泛使用的 Java 单元测试框架,主要用于编写和运行可重复的测试。以下是 JUnit 在项目测试中的使用方式和重点说明: 1. 基本使用 场景:测试一个简单的 Java 类。 示例: import org.junit.Test; import static org.junit.Assert.*;public class CalculatorTe…...

关于CNN,RNN,GAN,GNN,DQN,Transformer,LSTM,DBN你了解多少

以下是神经网络中常见的几种模型的简要介绍&#xff1a; 1. ​CNN (Convolutional Neural Network, 卷积神经网络) ​用途: 主要用于图像处理和计算机视觉任务。​特点: 通过卷积核提取局部特征&#xff0c;具有平移不变性&#xff0c;能够有效处理高维数据&#xff08;如图像…...

asp.net 4.5在医院自助系统中使用DeepSeek帮助医生分析患者报告

环境&#xff1a; asp.net 4.5Visual Studio 2015本地已经部署deepseek-r1:1.5b 涉及技术 ASP.NET MVC框架用于构建Web应用程序。使用HttpWebRequest和HttpWebResponse进行HTTP请求和响应处理。JSON序列化和反序列化用于构造和解析数据。SSE&#xff08;服务器发送事件&#xf…...

HeyGem.ai 全离线数字人生成引擎加入 GitCode:开启本地化 AIGC 创作新时代

在人工智能技术飞速演进的时代&#xff0c;数据隐私与创作自由正成为全球开发者关注的焦点。硅基智能旗下开源项目 HeyGem.ai 近日正式加入 GitCode&#xff0c;以全球首个全离线数字人生成引擎的颠覆性技术&#xff0c;重新定义人工智能生成内容&#xff08;AIGC&#xff09;的…...

密码协议与网络安全——引言

三个基本概念 计算机安全&#xff08;Computer Security&#xff09;&#xff1a;对于一个自动化的信息系统&#xff0c;采取保护措施确保信息系统资源&#xff08;包括硬件、软件、固件、信息、数据和通信&#xff09;的保密性、完整性和可用性。 网络安全&#xff08;Netwo…...

springboot实现调用百度ocr实现身份识别+二要素校验

一、技术选型 OCR服务&#xff1a;推荐使用百度AI 二、实现 1.注册一个服务 百度智能云控制台https://console.bce.baidu.com/ai-engine/ocr/overview/index?_1742309417611 填写完之后可以获取到app-id、apiKey、SecretKey这三个后面文件配置会用到 2、导入依赖 <!-- …...

MATLAB 控制系统设计与仿真 - 28

MATLAB状态空间控制系统分析 - 极点配置 就受控系统的控制律的设计而言,由状态反馈极点配置和输出反馈极点配置。 状态反馈极点配置问题就是:通过状态反馈矩阵K的选取,使闭环系统的极点,即(A-BK)的特征值恰好处于所希望的一组给定闭环极点的位置。 另外,线性定常系统可…...

JetsonNano —— 4、Windows下对JetsonNano板卡烧录刷机Ubuntu20.04版本(官方教程)

介绍 NVIDIA Jetson Nano™ 开发者套件是一款面向创客、学习者和开发人员的小型 AI 计算机。按照这个简短的指南&#xff0c;你就可以开始构建实用的 AI 应用程序、酷炫的 AI 机器人等了。 烧录刷机 1、下载 Jetson Nano开发者套件SD卡映像 解压出.img文件并记下它在计算机上的…...

加速还是安全?CDN与群联云防护的本质差异与适用场景

一、核心功能定位对比 维度传统CDN群联云防护核心目标内容加速&#xff08;降低延迟、提升访问速度&#xff09;安全防护&#xff08;抵御DDoS/CC攻击、隐藏源站&#xff09;技术重心缓存优化、边缘节点分发流量清洗、AI行为分析、加密隧道主要能力静态资源缓存、负载均衡攻击…...

简单理解机器学习中top_k、top_p、temperature三个参数的作用

在机器学习中&#xff0c;top_k、top_p 和 temperature 是用于控制生成模型&#xff08;如语言模型&#xff09;输出质量的参数&#xff0c;尤其在文本生成任务中常见。然而&#xff0c;网上文章很多很全&#xff0c;但大多晦涩难懂&#xff0c;今天我们来用最简单的语言谈谈它…...

Java面试黄金宝典6

1. 什么是 CAS 原理&#xff1a; CAS &#xff08;Compare-And-Swap&#xff09;是一种硬件级别的原子操作指令&#xff0c;在 Java 并发编程中常被用于实现无锁算法。其核心逻辑是&#xff1a;在进行数据更新时&#xff0c;会先将内存位置 V 的值与预期原值 A 进行比较&#x…...

【深度学习新浪潮】AI ISP技术与手机厂商演进历史

本文是关于AI ISP(人工智能图像信号处理器)的技术解析、与传统ISP(图像信号处理器)的区别、近三年研究进展,以及各大手机厂商在该领域演进历史的详细报告。本报告综合多个权威来源的信息,力求全面、深入地呈现相关技术发展脉络与行业动态。 第一部分:AI ISP的定义及与传…...

C语言基础08

内容提要 数组 排序算法&#xff1a;冒泡排序 二维数组 字符数组 数组 冒泡排序 排序思想&#xff08;向前冒泡&#xff09; 一次只排好一个数&#xff0c;针对n个数&#xff0c;最差情况需要n-1次就可以排好 每次排序假定第一个元素是最大或者最小&#xff0c;用第一个…...

基于Arm GNU Toolchain编译生成的.elf转hex/bin文件格式方法

基于Arm GNU Toolchain编译生成的.elf转hex/bin文件格式方法 已经弃用的版本&#xff08;Version 10.3-2021.10&#xff09;&#xff1a;gcc-arm-none-eabi&#xff1a;https://developer.arm.com/downloads/-/gnu-rmArm GNU Toolchain当前版本&#xff1a;https://developer.a…...

1.angular介绍

初級使用视频添加链接描述 angular工具 angular.module(‘名’, [依赖模块]) 模块 angular.bind(*) : 修改this指向 angualr.copy() // a angular.copy(a, b) —a完全覆盖了b,c就是a angular.extend(a, b) a里面集成了b属性 angular.isArray angular.isDate angular.isDefin…...

java项目40分钟后token失效问题排查(40分钟后刷新页面白屏)

项目40分钟后token失效问题排查&#xff08;40分钟后刷新页面白屏&#xff09; 经过我 对比失效前token 可以正常访问接口&#xff0c;失效后的token 不能访问系统&#xff0c; 得出结论&#xff0c;我系统对接第三方 sso 系统&#xff0c;token 失效时间 在他们那边配置&…...