目录

  • 1.其他数据库日志
    • 1.1.日志类型
    • 1.2.日志的弊端
  • 2.慢查询日志 (slow query log)
  • 3.通用查询日志 (general query log)
    • 3.1.问题场景
    • 3.2.查看当前状态
    • 3.3.启动日志
    • 3.4.查看日志
    • 3.5.停止日志
    • 3.6.删除/刷新日志
  • 4.错误日志 (error log)
    • 4.1.启动日志
    • 4.2.查看日志
    • 4.3.删除/刷新日志
  • 5.二进制日志 (bin log)
    • 5.1.查看默认情况
    • 5.2.日志参数设置
    • 5.3.查看日志
    • 5.4.使用日志恢复数据
    • 5.5.删除二进制日志
    • 5.6 其它场景
  • 6.再谈二进制日志 (binlog)
    • 6.1.写入机制
    • 6.2.bin log 与 redo log 对比
    • 6.3.两阶段提交
  • 7.中继日志 (relay log)
    • 7.1.介绍
    • 7.2.查看中继日志
    • 7.3.恢复的典型错误

本文笔记整理来自尚硅谷视频https://www.bilibili.com/video/BV1iq4y1u7vj/?p=187,相关资料可在视频评论区进行获取。

(1)在数据库事务中,讲过两种日志:重做日志回滚日志

(2)对于线上数据库应用系统,突然遭遇数据库宕机怎么办?在这种情况下,定位宕机的原因就非常关键。我们可以查看数据库的错误日志。因为日志中记录了数据库运行中的诊断信息,包括了错误、警告和注释等信息。比如:从日志中发现某个连接中的 SQL 操作发生了死循环,导致内存不足,被系统强行终止了。明确了原因,处理起来也就轻松了,系统很快就恢复了运行。

(3)除了发现错误,日志在数据复制、数据恢复、操作审计,以及确保数据的永久性和一致性等方面,都有着不可替代的作用。

(4)千万不要小看日志。很多看似奇怪的问题,答案往往就藏在日志里。很多情况下,只有通过查看日志才能发现问题的原因,真正解决问题。所以,一定要学会查看日志,养成检查日志的习惯,对提升你的数据库应用开发能力至关重要。

(5)MySQL8.0官网日志地址:https://dev.mysql.com/doc/refman/8.0/en/server-logs.html

1.其他数据库日志

1.1.日志类型

(1)MySQL 有不同类型的日志文件,用来存储不同类型的日志,分为二进制日志错误日志通用查询日志慢查询日志,这也是常用的 4 种。MySQL 8.0 又新增两种支持的日志:中继日志数据定义语句日志。使用这些日志文件,可以查看 MySQL 内部发生的事情。

  • 慢查询日志:记录所有执行时间超过 long_query_time 的所有查询,方便我们对查询进行优化。
  • 通用查询日志:记录所有连接的起始时间和终止时间,以及连接发送给数据库服务器的所有指令,对我们复原操作的实际场景、发现问题,甚至是对数据库操作的审计都有很大的帮助。
  • 错误日志:记录 MySQL 服务的启动、运行或停止 MySQL 服务时出现的问题,方便我们了解服务器的状态,从而对服务器进行维护。
  • 二进制日志:记录所有更改数据的语句,可以用于主从服务器之间的数据同步,以及服务器遇到故障时数据的无损失恢复。
  • 中继日志:用于主从服务器架构中,从服务器用来存放主服务器二进制日志内容的一个中间文件。从服务器通过读取中继日志的内容,来同步主服务器上的操作。
  • 数据定义语句日志:记录数据定义语句执行的元数据操作。

(2)除二进制日志外,其他日志都是文本文件。默认情况下,所有日志创建于MySQL数据目录中。

1.2.日志的弊端

(1)日志功能会降低MySQL数据库的性能。例如,在查询非常频繁的MysQL数据库系统中,如果开启了通用查询日志和慢查询日志,MySQL数据库会花费很多时间记录日志。

(2)日志会占用大量的磁盘空间。对于用户量非常大、操作非常频繁的数据库,日志文件需要的存储空间设置比数据库文件需要的存储空间还要大。

2.慢查询日志 (slow query log)

慢查询日志相关的知识点已经在MySQL高级篇知识点——性能分析工具的使用这篇文章中具体介绍过,此处就不再赘述。

3.通用查询日志 (general query log)

通用查询日志用来记录用户的所有操作,包括启动和关闭 MySQL 服务、所有用户的连接开始时间和截止时间、发给 MySQL 数据库服务器的所有 SQL 指令等。当我们的数据发生异常时,查看通用查询日志,还原操作时的具体场景,可以帮助我们准确定位问题。

3.1.问题场景

(1)在电商系统中,购买商品并且使用微信支付完成以后,却发现支付中心的记录并没有新增,此时用户再次使用支付宝支付,就会出现重复支付的问题。但是当去数据库中查询数据的时候,会发现只有一条记录存在。那么此时给到的现象就是只有一条支付记录,但是用户却支付了两次。

(2)我们对系统进行了仔细检查,没有发现数据问题,因为用户编号和订单编号以及第三方流水号都是对的。可是用户确实支付了两次,这个时候,我们想到了检查通用查询日志,看看当天到底发生了什么。

(3)查看之后,发现: 1 月 1 日下午 2 点,用户使用微信支付独以后,但是由于网络故障,支付中心没有及时收到微信支付的回调通知,导致当时没有写入数据。1 月 1 日下午 2 点 30,用户又使用支付宝支付,此时记录更新到支付中心。1 月 1 日晚上 9 点,微信的回调通知过来了,但是支付中心已经存在了支付宝的记录,所以只能覆盖记录了。

(3)由于网络的原因导致了重复支付。至于解决问题的方案就很多了,这里省略。

可以看到通用查询日志可以帮助我们了解操作发生的具体时间和操作的细节,对找出异常发生的原因极其关键。

3.2.查看当前状态

# linux
mysql> SHOW VARIABLES LIKE '%general%';
+------------------+------------------------------+
| Variable_name    | Value                        |
+------------------+------------------------------+
| general_log      | OFF                          | # 通用查询日志默认处于关闭状态
| general_log_file | /var/lib/mysql/atguigu01.log | # 通用查询日志文件的名称是 atguigu01.log (主机名.log)
+------------------+------------------------------+
2 rows in set (0.03 sec)# windows
mysql> SHOW VARIABLES LIKE '%general%';
+------------------+----------------------------------------------------------------+
| Variable_name    | Value                                                          |
+------------------+----------------------------------------------------------------+
| general_log      | OFF                                                            |
| general_log_file | C:\ProgramData\MySQL\MySQL Server 5.5\Data\LAPTOP.log          |
+------------------+----------------------------------------------------------------+
2 rows in set (0.01 sec)

说明 1:系统变量 general_log 的值是 OFF,即通用查询日志处于关闭状态。在 MySQL 中,这个参数的默认值是关闭的。因为一旦开启记录通用查询日志,MySQL 会记录所有的连接起止和相关的 SQL 操作,这样会消耗系统资源并且占用磁盘空间。我们可以通过手动修改变量的值,在需要的时候开启日志。

说明 2:通用查询日志文件的名称是 atguiguo1.log。存储路径是 /var/lib/mysql/,默认也是数据路径。这样我们就知道在哪里可以查看通用查询日志的内容了。

3.3.启动日志

(1)永久性方式
修改 my.cnf 或者 my.ini 配置文件来设置。在[mysqld]组下加入 log 选项,并重启 MySQL 服务。格式如下:

[mysqld]
general_log=ON
general_log_file=[path[filename]] # 日志文件所在目录路径,filename 为日志文件名

如果不指定目录和文件名,通用查询日志将默认存储在 MySQL 数据目录中的 hostname.log 文件中,hostname 表示主机名。

(2)临时性方式

SET GLOBAL general_log=on; # 开启通用查询日志 SET GLOBAL general_log_file=’path/filename’; # 设置日志文件保存位置

对应的,关闭操作 SQL 命令如下:

SET GLOBAL general_log=off; # 关闭通用查询日志

查看设置后情况:

SHOW VARIABLES LIKE 'general_log%';

3.4.查看日志

(1)通用查询日志是以文本文件的形式存储在文件系统中的,可以使用文本编辑器直接打开日志文件。每台 MySQL 服务器的通用查询日志内容是不同的。

  • 在 Windows 操作系统中,使用文本文件查看器;
  • 在 Linux 系统中,可以使用 vi 工具或者 gedit 工具查看;
  • 在 Mac OS 系统中,可以使用文本文件查看器或者 vi 等工具查看。

(2)从 SHOW VARIABLES LIKE ‘general_log%’; 结果中可以看到通用查询日志的位置。

(3)在通用查询日志里面,我们可以清楚地看到,什么时候开启了新的客户端登陆数据库,登录之后做了什么 SQL 操作,针对的是哪个数据表等信息。

3.5.停止日志

(1)永久性方式
修改 my.cnf 或者 my.ini 文件,把[mysqld]组下的 general_log 值设置为 OFF 或者把 general_log 一项注释掉。修改保存后,再 重启MySQL服务 ,即可生效。

[mysqld]
general_log=OFF
# 或
[mysqld]
# general_log=ON

(2)临时性方式
使用 SET 语句停止 MySQL 通用查询日志功能:

SET GLOBAL general_log=off;

查询通用日志功能:

SHOW VARIABLES LIKE 'general_log%';

3.6.删除/刷新日志

(1)如果数据的使用非常频繁,那么通用查询日志会占用服务器非常大的磁盘空间。数据管理员可以删除很长时间之前的查询日志,以保证 MySQL 服务器上的硬盘空间。

(2)使用如下命令重新生成查询日志文件,具体命令如下。刷新 MySQL 数据目录,发现创建了新的日志文件。前提一定要开启通用日志。

mysqladmin -uroot -p flush-logs

4.错误日志 (error log)

(1)错误日志记录了 MySQL 服务器启动、停止运行的时间,以及系统启动、运行和停止过程中的诊断信息,包括错误警告提示等。
(2)通过错误日志可以查看系统的运行状态,便于即时发现故障、修复故障。如果 MySQL 服务出现异常,错误日志是发现问题、解决故障的首选

4.1.启动日志

(1)在 MySQL 数据库中,错误日志功能是默认开启的。而且,错误日志无法被禁止。默认情况下,错误日志存储在 MySQL 数据库的数据文件夹下,名称默认为 mysqld.log(Linux系统)或 hostname.err(mac系统)。

(2)如果需要制定文件名,则需要在 my.cnf 或者 my.ini 中做如下配置:

[mysqld]
log-error=[path/[filename]] # path为日志文件所在的目录路径,filename 为日志文件名

修改配置项后,需要重启MySQL服务以生效。

4.2.查看日志

MySQL 错误日志是以文本文件形式存储的,可以使用文本编辑器直接查看。查询错误日志的存储路径:

mysql> SHOW VARIABLES LIKE 'log_err%';
+----------------------------+----------------------------------------+
| Variable_name              | Value                                  |
+----------------------------+----------------------------------------+
| log_error                  | /var/log/mysqld.log                    |
| log_error_services         | log_filter_internal; log_sink_internal |
| log_error_suppression_list |                                        |
| log_error_verbosity        | 2                                      |
+----------------------------+----------------------------------------+
4 rows in set (0.01 sec)

执行结果中可以看到错误日志文件是 mysqld.log,位于 MySQL 默认的数据目录下。

4.3.删除/刷新日志

对于很久以前的错误日志,数据库管理员查看这些错误日志的可能性不大,可以将这些错误日志删除,以保证 MySQL 服务器上的 硬盘空间 。MySQL 的错误日志是以文本文件的形式存储在文件系统中的,可以直接删除。

[root@atguigu01 log]# mysqladmin -uroot -p flush-logs
Enter password:
mysqladmin: refresh failed; error: 'Could not open file '/var/log/mysqld.log' for error logging.'

官网提示:

补充操作:

install -omysql -gmysql -m0644 /dev/null /var/log/mysqld.log

flush-logs 指令操作:

  • MySQL 5.5.7 以前的版本,flush-logs 将错误日志文件重命名为 filename.err_old,并创建新的日志文件。
  • 从MySQL 5.5.7 开始,flush-logs 只是重新打开日志文件,并不做日志备份和创建的操作。
  • 如果日志文件不存在,MySQL 启动或者执行 flush-logs 时会自动创建新的日志文件。重新创建错误日志,大小为 0 字节。

5.二进制日志 (bin log)

(1)binlog 可以说是 MySQL 中比较重要的日志了,在日常开发及运维过程中,经常会遇到。
(2)binlog 即 binary log,二进制日志文件,也叫作变更日志 (update log)。它记录了数据库所有执行的 DDL 和 DML 等数据库更新事件的语句,但是不包含没有修改任何数据的语句(如数据查询语句 select、 show 等)。
(3)它以事件形式记录并保存在二进制文件中。通过这些信息,我们可以再现数据更新操作的全过程。

如果想要记录所有语句(例如,为了识别有问题的查询),需要使用通用查询日志。

(4)binlog主要应用场景:

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

(5)可以说 MySQL 数据库的数据备份、主备、主主、主从都离不开 binlog,需要依靠 binlog 来同步数据,保证数据一致性。

5.1.查看默认情况

查看记录二进制日志是否开启:在 MySQL 8 中默认情况下,二进制文件是开启的。

mysql> show variables like '%log_bin%';
+---------------------------------+----------------------------------+
| Variable_name                   | Value                            |
+---------------------------------+----------------------------------+
| log_bin                         | ON                               |
| log_bin_basename                | /var/lib/mysql/binlog            |
| log_bin_index                   | /var/lib/mysql/binlog.index      |
| log_bin_trust_function_creators | OFF                              |
| log_bin_use_v1_row_events       | OFF                              |
| sql_log_bin                     | ON                               |
+---------------------------------+----------------------------------+
6 rows in set (0.00 sec)

5.2.日志参数设置

(1)永久性方式
修改 MySQL 的 my.cnf 或 my.ini 文件可以设置二进制日志的相关参数:

[mysqld]#启用二进制日志 log-bin=atguigu-bin             # 日志名称binlog_expire_logs_seconds=600  # 日志保存时间,单位是秒max_binlog_size=100M            # 日志最大大小

重新启动 MySQL 服务,查询二进制日志的信息,执行结果:

mysql> show variables like '%log_bin%';
+---------------------------------+------------------------------------------+
| Variable_name                   | Value                                    |
+---------------------------------+------------------------------------------+
| log_bin                         | ON                                       |
| log_bin_basename                | /var/lib/mysql/atguigu-binlog            |
| log_bin_index                   | /var/lib/mysql/atguigu-binlog.index      |
| log_bin_trust_function_creators | OFF                                      |
| log_bin_use_v1_row_events       | OFF                                      |
| sql_log_bin                     | ON                                       |
+---------------------------------+------------------------------------------+
6 rows in set (0.00 sec)


设置带文件夹的bin-log日志存放目录:如果想改变日志文件的目录和名称,可以对 my.cnf 或 my.ini 中的 log_bin 参数修改如下:

[mysqld]
log-bin="/var/lib/mysql/binlog/atguigu-bin"

注意:新建的文件夹需要使用mysql用户,使用下面的命令即可。

chown -R -v mysql:mysql binlog

重启 MySQL 服务之后,新的二进制日志文件将出现在 /var/lib/mysq/binlog/ 文件夹下面。

提示:数据库文件最好不要与日志文件放在同一个磁盘上!这样,当数据库文件所在的磁盘发生故障时,可以使用日志文件恢复数据。

(2)临时性方式
如果不希望通过修改配置文件并重启的方式设置二进制日志的话,还可以使用如下指令,需要注意的是在 MySQL 8 中只有 会话级别 的设置,没有了 global 级别的设置。

# global 级别
mysql> set global sql_log_bin=0;
ERROR 1228 (HY000): Variable 'sql_log_bin' is a SESSION variable and can`t be used with SET GLOBAL # session级别
mysql> SET sql_log_bin=0;
Query OK, 0 rows affected (0.01 秒)

5.3.查看日志

(1)当 MySQL 创建二进制日志文件时,先创建一个以“filename”为名称、以“.index”为后缀的文件,再创建一个以“filename”为名称、以“.000001”为后缀的文件。MySQL 服务重新启动一次 ,以“.000001”为后缀的文件就会增加一个,并且后缀名按1递增。即日志文件的个数与 MySQL 服务启动的次数相同;如果日志长度超过了 max_binlog_size 的上限(默认是 1GB),就会创建一个新的日志文件。

(2)查看当前的二进制日志文件列表及大小。指令如下:

mysql> SHOW BINARY LOGS;
+--------------------+-----------+-----------+
| Log_name           | File_size | Encrypted |
+--------------------+-----------+-----------+
| atguigu-bin.000001 | 156       | No        |
+--------------------+-----------+-----------+
1 行于数据集 (0.02 秒)

所有对数据库的修改都会记录在 binglog 中。但 binlog 是二进制文件,无法直接查看,想要更直观的观测它就要借助 mysqlbinlog 命令工具了。指令如下所示。

mysqlbinlog -v "/var/lib/mysql/binlog/atguigu-bin.000002"# 不显示 binlog 格式的语句
mysqlbinlog -v --base64-output=DECODE-ROWS "/var/lib/mysql/binlog/atguigu-bin.000002"

在查看执行,先执行一条 SQL 语句,如下所示:

update student set name='张三_back ' where id = 1;

开始查看 binlog:


前面的命令同时显示binlog格式的语句,使用如下命令不显示它

关于 mysqlbinlog 工具的使用技巧还有很多,例如只解析对某个库的操作或者某个时间段内的操作等。简单分享几个常用的语句,更多操作可以参考官方文档。

# 可查看参数帮助
mysqlbinlog --no-defaults --help # 查看最后100行
mysqlbinlog --no-defaults --base64-output=decode-rows -vv atguigu-bin.000002 |tail -100 # 根据position查找
mysqlbinlog --no-defaults --base64-output=decode-rows -vv atguigu-bin.000002 |grep -A20 '4939002'

上面这种办法读取出 binlog 日志的全文内容比较多,不容易分辨查看到 pos 点信息,下面介绍一种更为方便的查询命令:

mysql> show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count];
  • IN 'log_name':指定要查询的 binlog 文件名(不指定就是第一个 binlog 文件)
  • FROM pos:指定从哪个 pos 起始点开始查起(不指定就是从整个文件首个 pos 点开始算)
  • LIMIT [offset]:偏移量(不指定就是 0)
  • row_count:查询总条数(不指定就是所有行)
mysql> show binlog events in 'atguigu-bin.000002';


5.4.使用日志恢复数据

如果 MySQL 服务器启用了二进制日志,在数据库出现意外丢失数据时,可以使用 MySQLbinlog工具从指定的时间点开始(例如,最后一次备份)直到现在或另一个指定的时间点的日志中恢复数据。mysqlbinlog 恢复数据的语法如下:

mysqlbinlog [option] filename|mysql –uuser -ppass;

这个命令可以这样理解:使用 mysqlbinlog 命令来读取 filename 中的内容,然后使用 mysql 命令将这些内容恢复到数据库中。

  • filename:是日志文件名。
  • option:可选项,比较重要的两对option参数是–start-date、–stop-date 和 --start-position、-- stop-position。
    • --start-date 和 --stop-date:可以指定恢复数据库的起始时间点和结束时间点。
    • --start-position和--stop-position:可以指定恢复数据的开始位置和结束位置。

注意:使用 mysqlbinlog 命令进行恢复操作时,必须是编号小的先恢复,例如 atguigu-bin.000001 必须在 atguigu-bin.000002 之前恢复。

5.5.删除二进制日志

MySQL 的二进制文件可以配置自动删除,同时 MySQL 也提供了安全的手动删除二进制文件的方法。PURGE MASTER LOGS 只删除指定部分的二进制日志文件, RESET MASTER 删除所有的二进制日志文件。具体如下:

(1)PURGE MASTER LOGS:删除指定日志文件

PURGE {MASTER | BINARY} LOGS TO '指定日志文件名'
PURGE {MASTER | BINARY} LOGS BEFORE '指定日期'

(2)RESET MASTER:删除所有二进制日志文件
使用 RESET MASTER 语句,清空所有的 binlog 日志。MySQL 会重新创建二进制文件,新的日志文件扩展名将重新从 000001 开始编号。一定要慎用!

5.6 其它场景

(1)二进制日志可以通过数据库的全量备份和二进制日志中保存的增量信息,完成数据库的无损失恢复。但是,如果遇到数据量大、数据库和数据表很多(比如分库分表的应用)的场景,用二进制日志进行数据恢复,是很有挑战性的,因为起止位置不容易管理。

(2)在这种情况下,一个有效的解决办法是配置主从数据库服务器,甚至是一主多从的架构,把二进制日志文件的内容通过中继日志,同步到从数据库服务器中,这样就可以有效避免数据库故障导致的数据异常等问题。

6.再谈二进制日志 (binlog)

6.1.写入机制

(1)binlog 的写入时机也非常简单,事务执行过程中,先把日志写到 binlog cache,事务提交的时候,再把 binlog cache 写到 binlog 文件中。因为一个事务的 binlog 不能被拆开,无论这个事务多大,也要确保一次性写入,所以系统会给每个线程分配一个块内存作为 binlog cache。

(2)我们可以通过 binlog_cache_size 参数控制单个线程 binlog cache 大小,如果存储内容超过了这个参数,就要暂存到磁盘 (Swap)。binlog 日志刷盘流程如下:

上图中的 write 是指把日志写入到文件系统的page cache,并没有把数据持久化到磁盘,所以速度比较快。而 fsync 才是将数据持久化到磁盘的操作。

write 和 fsync 的时机,可以由参数 sync_binlog 控制,默认是 0。为 0 的时候,表示每次提交事务都只 write,由系统自行判断什么时候执行 fsync。虽然性能得到提升,但是机器宕机,page cache 里面的 binglog 会丢失。如下图:

为了安全起见,可以设置为 1 ,表示每次提交事务都会执行 fsync,就如同 redo log 刷盘流程一样。最后还有一种折中方式,可以设置为 N (N>1),表示每次提交事务都 write,但累积 N 个事务后才 fsync。

在出现 I/O 瓶颈的场景里,将 sync_binlog 设置成一个比较大的值,可以提升性能。同样的,如果机器宕机,会丢失最近 N 个事务的 binlog 日志。

6.2.bin log 与 redo log 对比

  • redo log 它是物理日志,记录内容是“在某个数据页上做了什么修改”,属于 InnoDB 存储引擎层产生的。
  • bin log 是逻辑日志,记录内容是语句的原始逻辑,类似于“给 ID=2 这一行的 c 字段加 1”,属于 MySQL Server 层。
  • 虽然它们都属于持久化的保证,但是则重点不同
    • redo log 让 InnoDB 存储引擎拥有了崩溃恢复能力。
    • binlog 保证了 MySQL 集群架构的数据一致性。

6.3.两阶段提交

(1)在执行更新语句过程,会记录 redo log 与 binlog 两块日志,以基本的事务为单位,redo log在事务执行过程中可以不断写入,而 bin log 只有在提交事务时才写入,所以 redo log 与 binlog 的写入时机不一样。

(2)redo log 与 binlog 两份日志之间的逻辑不一致,会出现什么问题?

以 update 语句为例,假设 id=2 的记录,字段 c 值是 e,把字段 c 值更新成 1,SQL 语句为 update T set c=1 where id=2。假设执行过程中写完 redo log 日志后,binlog 日志写期间发生了异常,会出现什么情况呢?

由于 binlog 没写完就异常,这时候 binlog 里面没有对应的修改记录。因此,之后用 binlog 日志恢复数据时,就会少这一次更新,恢复出来的这一行 c 值是 0,而原库因为 redo log 日志恢复,这一行 c 值是 1,最终数据不一致

(3)为了解决两份日志之间的逻辑一致问题,InnoDB 存储引擎使用两阶段提交方案。原理很简单,将 redo log 的写入拆成了两个步骤 prepare 和 commit,这就是两阶段提交

使用两阶段提交后,写入 binlog 时发生异常也不会有影响,因为 MySQL 根据 redo log 日志恢复数据时,发现 redo log 还处于 prepare 阶段,并且没有对应 binlog 日志,就会回滚该事务

另一个场景,redo log 设置 commit 阶段发生异常,那会不会回滚事务呢?

并不会回滚事务,它会执行上图框住的逻辑,虽然 redo log 是处于 prepare 阶段,但是能通过事务 id 找到对应的 binlog 日志,所以 MySQL 认为是完整的,就会提交事务恢复数据。

7.中继日志 (relay log)

7.1.介绍

(1)中继日志只在主从服务器架构的从服务器上存在。从服务器为了与主服务器保持一致,要从主服务器读取二进制日志的内容,并且把读取到的信息写入本地的日志文件中,这个从服务器本地的日志文件就叫中继日志。然后,从服务器读取中继日志,并根据中继日志的内容对从服务器的数据进行更新,完成主从服务器的数据同步

(2)搭建好主从服务器之后,中继日志默认会保存在从服务器的数据目录下。文件名的格式是:从服务器名 -relay-bin.序号。中继日志还有一个索引文件:从服务器名 -relay-bin.index,用来定位当前正在使用的中继日志。

7.2.查看中继日志

中继日志与二进制日志的格式相同,可以用 mysqlbinlog 工具进行查看。下面是中继日志的一个片段:

这一段的意思是,主服务器 (“server id 1”) 对表 atguigu.test 进行了 2 步操作:

定位到表 atguigu.test 编号是 91 的记录,日志位置是 832; 删除编号是 91 的记录,日志位置是 872。

7.3.恢复的典型错误

(1)如果从服务器宕机,有时为了系统恢复,要重装操作系统,这样就可能会导致服务器名称与之前不同。而中继日志里是包含从服务器名的。在这种情况下,就可能导致你恢复从服务器的时候,无法从宕机前的中继日志里读取数据,以为是日志文件损坏了,其实是名称不对了。

(2)解决的方法也很简单,把从服务器的名称改回之前的名称

MySQL高级篇知识点——其它数据库日志相关推荐

  1. MySQL高级篇知识点——索引优化与查询优化

    目录 1.数据准备 1.1.建库建表 1.2.创建相关函数 1.3.创建存储过程 1.4.调用存储过程 1.5.删除某表上的索引 2.索引失效案例 2.1.全值匹配 2.2.最佳左前缀匹配原则 2.3 ...

  2. MySQL高级篇知识点——数据库的设计规范

    目录 1.为什么需要数据库设计? 2.范式 2.1.范式简介 2.2.范式都包括哪些 2.3.键和相关属性的概念 2.4.第一范式 (1NF) 2.5.第二范式 (2NF) 2.6.第三范式 (3NF ...

  3. MySQL高级篇知识点——MySQL 事务日志

    目录 1.redo 日志 1.1.为什么需要 REDO 日志? 1.2.REDO 日志的好处与特点 1.3.redo 的组成 1.4.redo 的整体流程 1.5.redo log 的刷盘策略 1.6 ...

  4. MySQL高级篇知识点——索引的数据结构

    目录 1.为什么使用索引 2.索引及其优缺点 2.1.索引概述 2.2.优点 2.3.缺点 3.InnoDB 中索引的推演 3.1.索引之前的查找 3.1.1.在一个页中的查找 3.1.2.在很多页中 ...

  5. 【MySQL高级篇笔记-MySQL事务日志(下) 】

    此笔记为尚硅谷MySQL高级篇部分内容 目录 一.redo日志 1.为什么需要REDO日志 2.REDO日志的好处.特点 3.redo的组成 4.redo的整体流程 5.redo log的刷盘策略 6 ...

  6. mysql高级篇学习笔记

    目录 前言 1 mysql安装及运行(linux环境) 1.1 安装前检查 1.2 MySQL卸载 ①**关闭 mysql 服务** ②**查看当前 mysql 安装状况** ③**卸载上述命令查询出 ...

  7. mysql高级篇(二)mysql索引优化分析

    mysql高级篇笔记 mysql高级篇(一)mysql的安装配置.架构介绍及SQL语句的复习. mysql高级篇(二)mysql索引优化分析. mysql高级篇(三)查询截取分析(慢查询日志).主从复 ...

  8. MySQL高级篇(事务视图存储过程与函数)

    目录 一.事务 1.1什么是事务? 1.2事务的特性 1.3事务的分类 1.4事务的操作步骤 1.5事务的隔离级别(面试题常考) 二.视图 2.1视图的操作 2.1.1视图的创建 2.1.2视图更新( ...

  9. MySQL高级篇_第12章_数据库其它调优策略

    1. 数据库调优的措施 1.1 调优的目标 尽可能节省系统资源,以便系统可以提供更大负荷的服务.(吞吐量更大) 合理的结构设计和参数调整,以提高用户操作响应的速度.(响应速度更快) 减少系统的瓶颈,提 ...

最新文章

  1. SQL SERVER中什么情况会导致索引查找变成索引扫描
  2. 利用计算机技术执行去自动化,计算机技术和自动化的关系.doc
  3. 3310复刻版 java_终于等到你:诺基亚3310复刻版开箱简评
  4. R语言文本挖掘NASA数据网络分析,tf-idf和主题建模
  5. 安装 Cacti 监控
  6. TCP/IP 与OSI结构图
  7. 复习之 c实现 通讯录
  8. VTK:PolyData之InterpolateMeshOnGrid
  9. devserver配置_03-零基础学webpack4.0之html相关配置
  10. C# MVC 项目下的路由配置-RouteConfig
  11. GIS集成技术之二:数据集成
  12. phpstudy_pro MySQL启动失败的原因
  13. 心率 心律 脉率的区别
  14. 验证guid()类型值的函数
  15. 固定频率调用接口方案
  16. java day63【 SSM 整合 】
  17. 常见数学符号及其读法
  18. linux环境编程apue和unp,《APUE》和《UNP》文件的编译和使用(转载)
  19. angular/js/vue ---表格内部换行
  20. 车金融|金融产品规则引擎的前世今生(中篇)

热门文章

  1. easy-captcha实现验证码功能
  2. python爬虫chinaplay网页的前十个游戏 游戏名字、原价、现价、折扣、爬下来输出到excel文件
  3. 如何用js实现简单的页面html动态加载(“看更多“/页面折叠功能)
  4. 要不要借钱给朋友和投资股票的共性
  5. DEEPIN 安装软件的方法
  6. android 退出app代码_PPT 下载 | APP 埋点那些事
  7. 【elasticSearch】 _cat命令详解
  8. 】20款优秀的移动产品原型和线框图设计工具
  9. 中科大和东北大学计算机考研,中科大计算机研究生一个月补助多少阿
  10. 100个球两个人轮流拿,每次最多拿n个,谁拿到最后一个球获胜