Mysql中的undo log和redo log, bin log的介绍

undo log的作用

undo log是Mysql实现"原子性"的重要方法. 在事务开启时, Mysql就会将该事务执行的命令记录到undo log中, 如果在提交事务前, 就发生了服务器崩溃, 执行 "回滚" 操作时就会读取undo log中记录的这些操作,并执行与其相反的操作达到恢复数据的目的.

例如: 在执行" delete * from students where id='1'; " 此时会将原来的值先记录下来,回滚时再将数据进行插入回去即可.

对于insert, update等等操作都类似于"执行相反的操作达到回滚的目的"

redo log的作用

redo log是Mysql进行持久化的重要操作. Mysql每进行数据的更新,删除等操作时就会将执行后的数据存放到redo log中, 如果数据库发生崩溃,就可以立即读取redo log中的数据进行恢复, 恢复后就是崩溃前的最新数据.

redo log采用了WAL(Write Ahead Logging)的机制, 即: 在写入硬盘前,先写入日志当中. 再由一个后台线程进行写入硬盘

bin log的作用

它是在Mysql的Server层日志,记录所有数据变更逻辑操作,用于主从复制和数据恢复。

Mysql的主从复制

  1. 当主库接收到客户端的请求时, 就会开启事务处理这些请求, 并在提交事务前将数据先写入到bin log中.

  2. 主库bin log写好后, 会从一个专门的"log dump"线程将bin log传给所有的从库.

  3. 此时每个从库也都有自己一个专属的I/O线程用来接收主库的bin log. 并将接收到的bin log存入到relay log中

  4. 从库接收到bin log之后就会利用自己一个专门的SQL线程用来读取relay log中的日志数据并同步到自己的数据库中.

主从复制策略

同步复制:

主库将bin log发给所有从库中, 必须要等待所有的从库同步完后,返回响应才能完成复制. 这种策略一旦从库多了,会消耗大量系统资源, 导致系统卡顿.

异步复制:

主库将bin log发给从库后, 无需等待复制完成,可以进行其他操作.

半同步复制:

主库将bin log发给从库后, 需要等待一部分的从库返回复制完成的响应.

当有一个主库和两个从库时,只需要等待一个从库返回复制完成的响应即可

相关推荐
liuyouzhang2 小时前
将基于Archery的web数据库审计查询平台封装为jdbc接口的可行性研究(基于AI)
前端·数据库
Meepo_haha5 小时前
配置 Redis
数据库·redis·缓存
u0109147607 小时前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
baidu_340998827 小时前
Golang怎么用go-noescape优化性能_Golang如何使用编译器指令控制逃逸分析行为【进阶】
jvm·数据库·python
m0_678485457 小时前
如何利用虚拟 DOM 实现无痕刷新?基于 VNode 对比的状态保持技巧
jvm·数据库·python
qq_342295827 小时前
CSS如何实现透明背景效果_通过RGBA色彩模式控制透明度
jvm·数据库·python
panzer_maus7 小时前
MySQL 索引介绍与索引优化的简单介绍
数据库·mysql
Greyson17 小时前
CSS如何处理超长文本换行问题_结合word-wrap属性
jvm·数据库·python
captain3767 小时前
事务___
java·数据库·mysql
justjinji7 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python