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

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

相关推荐
无限进步_7 分钟前
【C++】从红黑树到 map 和 set:封装设计与迭代器实现
开发语言·数据结构·数据库·c++·windows·github·visual studio
橙子圆12314 分钟前
Redis知识2
java·数据库·redis
过期动态17 分钟前
【RabbitMQ基础篇】RabbitMQ从入门到实战
java·jvm·数据库·分布式·spring·rabbitmq·intellij-idea
MandalaO_O17 分钟前
MySQL:数据库约束
数据库·mysql
刘~浪地球35 分钟前
MongoDB聚合管道进阶:数据处理与统计分析
数据库·mongodb
瀚高PG实验室36 分钟前
debezium在LANG=zh_CN.UTF-8下,无法解析timestamp类型的列值为BC的字段
服务器·数据库·postgresql·瀚高数据库
刘~浪地球36 分钟前
MongoDB索引优化实战:让查询飞起来
数据库·mongodb
AstartesEternal1 小时前
REDIS下载及安装教程
数据库·redis·缓存
Allen_LVyingbo1 小时前
面向医疗群体智能的协同诊疗与群体决策支持系统(上)
数据结构·数据库·人工智能·git·python·动态规划