来源:捡田螺的小男孩
前言
大家好,我是捡田螺的小男孩。最近行情越来越卷了,给大家整理了15道经典MySQL日志面试题,希望大家都能找到理想的offer
redo log是什么? 为什么需要redo log?
什么是WAL技术, 好处是什么
redo log的写入方式
redo log的执行流程
redo log 为什么可以保证crash safe机制呢?
binlog的概念是什么, 起到什么作用, 可以保证crash-safe吗?
binlog和redolog的不同点有哪些?
执行器和innoDB在执行update语句时候的流程是什么样的?
.如果数据库误操作, 如何执行数据恢复?
说说binlog日志三种格式
什么是MySQL两阶段提交, 为什么需要两阶段提交?
如果不是两阶段提交, 先写redo log和先写bin log两种情况各会遇到什么问题?
binlog刷盘机制
undo log 是什么?它有什么用
说说redo log的记录方式
1. redo log是什么? 为什么需要redo log?
redo log 是什么呢?
为什么需要 redo log?
2. 什么是WAL技术, 好处是什么.
3. redo log的写入方式
redo log包括两部分内容,分别是内存中的日志缓冲(redo log buffer)和磁盘上的日志文件(redo log file)。
mysql每执行一条DML语句,会先把记录写入redo log buffer,后续某个时间点再一次性将多个操作记录写到redo log file。这种先写日志,再写磁盘的技术,就是WAL。
在计算机操作系统中,用户空间(user space)下的缓冲区数据,一般是无法直接写入磁盘的,必须经过操作系统内核空间缓冲区(即OS Buffer)。
fsync(),从OS buffer写入到磁盘上的redo log file中,完成写入操作。这个写入磁盘的操作,就叫做刷盘。
我们可以发现,redo log buffer写入到redo log file,是经过OS buffer中转的。其实可以通过参数innodb_flush_log_at_trx_commit进行配置,参数值含义如下:
4. redo log的执行流程
我们来看下redo log的执行流程,假设执行的SQL如下:
update T set a =1 where id =666

update T set a =1 where id =666,发往MySQL Server层。5. redo log 为什么可以保证crash safe机制呢?
6. binlog的概念是什么, 起到什么作用, 可以保证crash-safe吗?
7. binlog和redolog的不同点有哪些?
| redo log | binlog | |
| 作用 | 用于崩溃恢复 | 主从复制和数据恢复 |
| 实现方式 | InnoDb存储引擎实现 | Server 层实现的,所有引擎都可以使用 |
| 记录方式 | 循环写的方式记录,写到结尾时,会回到开头循环写日志 | 通过追加的方式记录,当文件尺寸大于配置值后,后续日志会记录到新的文件上 |
| 文件大小 | 文件大小是固定的 | 通过配置参数max_binlog_size 设置每个binlog文件大小 |
| crash-safe能力 | 具有 | 没有 |
| 日志类型 | 物理日志 记录的是“在某个数据页上做了什么修改” | 逻辑日志 记录的是这个语句的原始逻辑 |
8. 执行器和innoDB在执行update语句时候的流程是什么样的?
9. 如果数据库误操作, 如何执行数据恢复?

数据库在某个时候误操作,就可以找到距离误操作最近的时间节点的bin log,重放到临时数据库里,然后选择误删的数据节点,恢复到线上数据库。
10. binlog日志三种格式
binlog日志有三种格式
Statement格式
每一条会修改数据的sql都会记录在binlog中
Row格式
不记录sql语句上下文相关信息,仅保存哪条记录被修改。
Mixed格式
实际上就是Statement与Row的结合。一般的语句修改使用statment格式保存binlog,如一些函数,statement无法完成主从复制的操作,则采用row格式保存binlog,MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志形式
11. 什么是MySQL两阶段提交, 为什么需要两阶段提交?
其实所谓的两阶段就是把一个事务分成两个阶段来提交。

两阶段提交主要有三步曲:
为什么需要两阶段提交呢?
12. 如果不是两阶段提交, 先写redo log和先写bin log两种情况各会遇到什么问题?
13. binlog刷盘机制
所有未提交的事务产生的binlog,都会被先记录到binlog的缓存中。等该事务提交时,再将缓存中的数据写入binlog日志文件中。缓存的大小由参数binlog_chache_size控制。
binlog什么时候刷新到磁盘呢?由参数sync_binlog控制
sync_binlog为0时,表示MySQL不控制binlog的刷新,而是由系统自行判断何时写入磁盘。选这种策略,一旦操作系统宕机,缓存中的binlog就会丢失。sync_binlog为N时,每N个事务,才会将binlog写入磁盘。。sync_binlog为1时,则表示每次commit,都将binlog 写入磁盘。来看一个比较完整的流程图吧:

14.undo log 是什么?它有什么用

15. 说说Redo log的记录方式
redo log的大小是固定。它采用循环写的方式记录,当写到结尾时,会回到开头循环写日志。如下图(图片来源网络):

redo log buffer(内存中)是由首尾相连的四个文件组成的,它们分别是:ib_logfile_1、ib_logfile_2、ib_logfile_3、ib_logfile_4。
write pos表示当前写入记录位置(写入磁盘的数据页的逻辑序列位置) check point表示刷盘(写入磁盘)后对应的位置。 write pos到check point之间的部分用来记录新日志,也就是留给新记录的空间。 check point到write pos之间是待刷盘的记录,如果不刷盘会被新记录覆盖。
有了 redo log,当数据库发生宕机重启后,可通过 redo log将未落盘的数据(check point之后的数据)恢复,保证已经提交的事务记录不会丢失,这种能力称为crash-safe。
