数据库
首页 > 数据库> > MySQL日志15连问

MySQL日志15连问

作者:互联网

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)。

我们可以发现,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
复制代码

Redo log的执行流程

  1. MySQL客户端将请求语句update T set a =1 where id =666,发往MySQL Server层。
  2. MySQL Server 层接收到SQL请求后,对其进行分析、优化、执行等处理工作,将生成的SQL执行计划发到InnoDb存储引擎层执行。
  3. InnoDb存储引擎层将a修改为1的这个操作记录到内存中。
  4. 记录到内存以后会修改redo log 的记录,会在添加一行记录,其内容是需要在哪个数据页上做什么修改
  5. 此后,将事务的状态设置为prepare ,说明已经准备好提交事务了。
  6. 等到MySQL Server层处理完事务以后,会将事务的状态设置为commit,也就是提交该事务。
  7. 在收到事务提交的请求以后,redo log会把刚才写入内存中的操作记录写入到磁盘中,从而完成整个日志的记录过程。

5. redo log 为什么可以保证crash safe机制呢?

6. binlog的概念是什么, 起到什么作用, 可以保证crash-safe吗?

7. binlog和redolog的不同点有哪些?

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两阶段提交, 为什么需要两阶段提交?

其实所谓的两阶段就是把一个事务分成两个阶段来提交。

两阶段提交

两阶段提交主要有三步曲:

  1. redo log在写入后,进入prepare状态
  2. 执行器写入bin log
  3. 进入commit状态,事务可以提交。

为什么需要两阶段提交呢?

12. 如果不是两阶段提交, 先写redo log和先写bin log两种情况各会遇到什么问题?

13. binlog刷盘机制

所有未提交的事务产生的binlog,都会被先记录到binlog的缓存中。等该事务提交时,再将缓存中的数据写入binlog日志文件中。缓存的大小由参数binlog_chache_size控制。

binlog什么时候刷新到磁盘呢?由参数sync_binlog控制

来看一个比较完整的流程图吧:

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

15. 说说Redo log的记录方式

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


 

标签:binlog,15,log,记录,写入,连问,MySQL,日志,redo
来源: https://blog.csdn.net/pengjianglilive/article/details/121171421