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发给从库后, 需要等待一部分的从库返回复制完成的响应.

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

相关推荐
卷Java3 小时前
Python字典:键值对、get()方法、defaultdict,附通讯录实战
开发语言·数据库·python
wanhengidc3 小时前
跨境云手机适用于哪些场景
大数据·运维·服务器·数据库·科技·智能手机
Bdygsl3 小时前
MySQL(6)—— 视图
数据库·mysql
oradh3 小时前
数据库入门概述
数据库·oracle·数据库基础·数据库入门
BullSmall4 小时前
一套定制化高级 payload 合集
数据库·安全性测试
zbdx不知名菜鸡4 小时前
postgre sql 数据库查询优化
数据库·postgresql
9稳4 小时前
基于PLC的生产线自动升降机设计
开发语言·网络·数据库·嵌入式硬件·plc
四七伵4 小时前
Spring Boot项目中varchar字段为什么不用NULL?告别空指针从建表开始
数据库·后端
Mr.45675 小时前
JDK17+Druid+SpringBoot3+ShardingSphere5 多表分库分表完整实践(MySQL+PostgreSQL)
java·数据库·spring boot·mysql·postgresql
Elastic 中国社区官方博客5 小时前
使用 ES|QL 变量控件将仪表板转变为调查工具
大数据·运维·服务器·数据库·elasticsearch·搜索引擎·全文检索