1、前言

MySQL相信大家都用过,但MySQL中都有哪些日志,是干什么的,估计有小伙伴还没有搞清楚。可能有小伙伴只知道最重要的三个:undolog、redolog、binlog。其实这是不全的,MySQL中的日志有:

undolog(回滚日志)、redolog(重做日志)、binlog(归档日志)、errorlog(错误日志)、slow query log(慢查询日志)、relaylog(中继日志),其中undolog、redolog、binlog是最常见和核心的。

2、MySQL日志

2.1、binlog(归档日志)

binlog是MySQL中的二进制日志文件,它可以记录MySQL上所有的修改和更新操作(注意:binlog日志是逻辑日志,记录的是SQL语句的原始逻辑,由Server层记录),包括DML(数据操作语言)和DDL(数据定义语言)操作。

运用场景

1、binlog是事务提交后生成的,所以一般用于恢复数据库。

2、在MySQL主从复制中,主库的binlog和从库的relaylog(中继日志)共同完成。

2.2、redolog(重做日志)

redolog是innodb存储引擎特有的日志文件(redolog日志是物理日志,记录的是物理数据页的更改,由innodb层记录)。

运用场景

主要用于确保事务的一致性和持久性,当数据库发生异常宕机后,可以通过redolog来进行数据的恢复。

2.3、undolog(回滚日志)

undolog日志中存储的是事务中写操作的回滚操作(可以简单理解为在事务中运行了一个insert语句,那么undolog就会存储一个delete语句,就是相反的意思),在一个事务中,如果发生异常,那么事务就会回滚,MySQL就会读取undolog进行回滚。

运用场景

1、主要用于事务中的回滚操作。

2、在MVCC(多版本并发控制)中用到了undolog,数据页记录中有两个隐藏列,分别是trx_id和roll_pointer,trx_id就是当前事务id,roll_pointer就是指向undolog地址的指针。

2.4、errorlog(错误日志)

错误日志是MySQL最常用的日志,注意记录MySQL服务器启动和停止过程中的信息、服务器在运行过程中发生的故障和异常情况等。

MySQL默认是开启errorlog的,默认存放路径为data包下,hostname.err的文件,hostname是你的主机名。

可以通过MySQL的配置文件中修改errorlog的存储路径,通过log-error和log-warnings来定义,其中log-error是否开启错误日志功能和定义存放errorlog的路径,log-warnings是否将警告信息记录到errorlog中。

2.5、relaylog(中继日志)

relaylog是MySQL数据库主从复制中使用的一种日志类型。它作用于在主数据库(master)和从数据库(slave)之间传递和存储复制,以达到主从复制的功能。

步骤1:Master将写操作记录到二进制日志binlog。

步骤2:Slave将Master的binlog events 拷贝到中继日志relaylog。

步骤3:Slave由SQL线程从relaylog重放事件,更新数据。

步骤4:给主库返回响应。

2.6、slow query log(慢查询日志)

slow query log(慢查询日志)是MySQL提供的一个排查慢SQL的日志,用于记录执行时间超过指定阈值的SQL语句。它在数据库性能调优方面非常有用。

(1)启动慢查询日志

通过修改MySQL配置文件my.cnf中的相关参数来启用慢查询日志,设置slow_query_log 为1来启用日志功能。

(2)设置超时阈值时间

配置long_query_time参数来指定慢查询的时间阈值(默认为10秒)。任何执行时间超过该值的SQL语句都将会记录到该日志文件中。

(3)指定日志的存储位置

通过设置slow_query_log_file参数来指定慢查询日志文件的存放位置和名称。

(4)查看和分析日志

通过mysqldumpslow命令或其他工具查询和分析慢查询日志。

(5)优化SQL

使用explain执行计划分析慢查询SQL,进行优化SQL。