MySQL redo log和binlog的区别

news2025/1/21 17:47:20

redo log和binlog的区别

Redo Log(重做日志):

  1. 作用

    • Redo Log是InnoDB存储引擎特有的一种日志,用于确保数据库的事务持久性和恢复能力。
  2. 特点

    • 存储在InnoDB的数据文件中,而不是作为单独的日志文件。
    • 记录的是物理数据页的更改信息,而不是逻辑操作。
    • 在事务提交时,将事务对数据页的物理修改操作记录到Redo Log中。
    • 用于恢复数据库的数据,当数据库发生异常宕机时,根据Redo Log中的记录重新执行事务,保证事务的持久性。
      擦头

Binlog(二进制日志):

  1. 作用

    • Binlog是MySQL服务器层产生的日志,记录了数据库的所有逻辑更改操作。
  2. 特点

    • 是以逻辑格式记录的日志,包含了对数据库进行修改的SQL语句。
    • 存储在独立的二进制日志文件中(如mysql-bin.000001)或作为表格中的记录。
    • 用于数据库复制、恢复和备份,以及实现主从复制功能。

在这里插入图片描述

主要区别:

  1. 日志类型

    • Redo Log是物理日志,记录了数据页的物理修改操作,用于数据库的恢复。
    • Binlog是逻辑日志,记录了SQL语句的执行顺序和内容,用于实现数据库的复制和恢复。
  2. 存储位置

    • Redo Log存储在InnoDB的数据文件中,与数据文件一起管理。
    • Binlog存储在独立的二进制日志文件中,或者作为表格中的记录,由MySQL服务器层管理。
  3. 应用场景

    • Redo Log用于保证事务的持久性和数据库的恢复能力,在数据库发生异常时通过Redo Log进行数据重做。
    • Binlog用于实现数据库的复制、恢复和备份,以及支持主从复制功能,通过重放Binlog中的SQL语句来实现数据同步和恢复。

总结:

  • Redo Log和Binlog都是MySQL中的日志,但用途和实现方式不同。
  • Redo Log保证了数据库的事务持久性和恢复能力,记录了物理数据页的修改操作。
  • Binlog记录了数据库的逻辑更改操作,用于数据库复制、恢复和备份等高级功能。

对不起,我理解您的疑问了。实际上,数据库恢复时会使用Redo Log来重放(replay)操作,以确保数据的一致性和持久性。

让我更详细地解释一下:

为什么不是重放Redo呢?

Redo Log(重做日志):

  • Redo Log是InnoDB存储引擎的一种日志,用于记录事务对数据页的物理修改操作。
  • 每当事务对数据库进行更改时,这些更改首先被记录到Redo Log中,然后再写入到磁盘上的数据文件。
  • Redo Log记录的是物理操作,包括数据页的修改信息,而不是SQL语句或逻辑操作。

数据库恢复过程中的Redo Log重放:

  • 当数据库发生异常宕机或崩溃时,可能存在未提交的事务或数据修改操作尚未写入磁盘。
  • 在数据库恢复过程中,系统会首先检查Redo Log,将其中记录的未提交的事务操作重新执行,以保证事务的持久性和数据库的一致性。
  • 通过重放Redo Log中的操作,数据库将之前未完成的事务操作重新应用到数据文件中,确保数据的完整性和正确性。

为什么是重放Redo Log而不是Binlog?

  • Binlog是MySQL服务器层产生的逻辑日志,用于记录SQL语句的执行顺序和内容,主要用于实现数据库的复制、恢复和备份。
  • 在数据库恢复过程中,如果只依赖Binlog进行恢复,需要重新执行所有SQL语句,这可能会导致数据不一致或错误。
  • 相比之下,Redo Log记录了物理数据页的修改操作,更直接地反映了事务对数据库的实际影响,因此在数据库恢复时更为可靠和高效。

因此,在数据库恢复过程中,重放Redo Log是确保数据库一致性和数据完整性的关键步骤。Binlog则更多用于数据库复制和备份等逻辑操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1576522.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CICD流水线 发布应用到docker镜像仓库

准备工作 1.先注册免费的镜像仓库 复制链接: https://cr.console.aliyun.com/cn-beijing/instances 实施 1. 新建流水线,选择模板 2.添加流水线源,及是你的代码仓库, 选择对应分支. 3.代码检查以及单元测试,这个步骤可以不用动它. 4. …

【C++】继承总结

一、前言 我们众所周知的C三大特性分别为:封装、继承、多态。 封装就是将接口实现统一化,隐藏那些不同的地方,在上层函数调用体现的方式一样,如各种容器的迭代器iterator,尽管底层实现的方式不同,但是在使用…

Java学习笔记23(面向对象三大特征)

1.5 多态 ​ *多态(polymorphic) ​ *方法或对象具有多种形态,是面向对象的第三大特征,多态是建立在封装和继承基础之上的 1.多态的具体体现 1.方法的多态 (重写和重载体现了多态) 2.对象的多态 ​ 1.一个对象的编译类型和…

亮数据----教你轻松获取数据

文章目录 1. 数据采集遇到的瓶颈1.1 不会造数据?1.2 不会写爬虫代码? 2.IP 代理基础知识2.1 基本概念2.2 作用和分类2.3 IP 代理的配置和使用2.4 安全和合规 3. 为何使用亮数据 IP 代理3.1 拥有丰富的代理网络服务3.2 简单易操作的采集工具3.3 拥有各平台…

爬虫入狱笔记——xx政府网站公开政策数据

最近在学习爬虫,做个笔记吧 今天爬xx政府网站-政策法规栏目的数据 咱们首先需要找到数据从哪里来,鼠标右键->检查(或者快捷键一般为F12)检查元素,搜索关键词 eg.【违法案例】 回车, 如果没有的话&am…

「媒体邀约」天津媒体邀约资源有哪些?媒体宣传现场报道

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 天津作为中国北方的重要城市,拥有丰富的媒体资源,可以为各类活动提供全面的媒体宣传和现场报道。以下是天津地区的媒体邀约资源: 1. 报纸媒体 - 《天…

「38」LUT在直播间调色的高级应用……

「38」LUT滤镜 对人或物进行精进调色 OBS软件中的LUT(Look Up Table)滤镜,可用于调整视频、图像的色彩和对比度等效果,以实现专业级的颜色调整需求。 左图为原图 右图为LUT 先对比上面的两张图,用了滤镜效果的变化…

【问题处理】银河麒麟操作系统实例分享,银河麒麟高级服务器操作系统mellanox 网卡驱动编译

1.Mellanox 网卡源码驱动下载链接: https://www.mellanox.com/downloads/ofed/MLNX_EN-5.7-1.0.2.0/MLNX_EN_SRC-5.7-1.0.2.0.tgz 2.系统及内核版本如下截图: 3.未升级前 mellanox 网卡驱动版本如下: 4.解压 “MLNX_EN_SRC-5.7-1.0.2.0.tg…

基于单片机电动自行车太阳能充电系统设计

**单片机设计介绍,基于单片机电动自行车太阳能充电系统设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机的电动自行车太阳能充电系统设计,是一个将太阳能技术与电动自行车充电技术相结合的创…

【RealSense】Ubuntu20.04 安装 Intel RealSense ROS 并使用 D435i 测试

【RealSense】Ubuntu20.04 安装 Intel RealSense ROS 并使用 D435i 测试 1 本机环境2 安装流程3 存在的 bug3.1 Resource not found: rgbd_launch 1 本机环境 Ubuntu20.04ROS Noetic 2 安装流程 参考文档: Link 安装 Intel RealSense™ SDK 2.0,参考上一篇文章: L…

微信小程序实现滚动标签

使用scroll-view标签可实现组件滚动标签 1、list中 list.wxml代码如下: <!--pages/list/list.wxml--> <navigation-bartitle"小程序" back"{{false}}"color"black" background"#FFF"></navigation-bar><scroll-…

「媒体宣传」科技IT行业有哪些媒体邀约资源-51媒体网

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 科技IT行业的媒体邀约资源非常丰富&#xff0c;包括了各种类型的传统媒体和新兴的网络媒体平台。以下是一些主要的媒体邀约资源&#xff1a; 除此之外&#xff0c;还有一些其他科技类网络…

finebi6.0中我的分析中...中加自己的菜单

js的两个扩展点是&#xff1a; BI.config("bi.result_wrapper", function (e) {return e.showMerge !0, e}),BI.config("bi.analysis.admin_list", function (e) {return e.showMergeUser !0, e}) 对应的组件在conf.min.js中的 bi.search_sort 点击事件…

【多线程】Callable详解

Callable接口 先看看Callable接口的源码: Callable是一个函数式接口&#xff0c;此时就可以用lambda表达式更简洁地使用它。Callable是个泛型接口&#xff0c;只有一个方法call&#xff0c;该方法返回类型就是传递进来的V类型。call方法还支持抛出异常. 与Callable对应的是Ru…

「媒体宣传」产业金融财经媒体邀约资源有哪些-51媒体

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 产业金融财经领域的媒体邀约资源涵盖了多种平台和形式&#xff0c;主要包括以下几类&#xff1a; 杂志和报纸&#xff1a;如《中国经济周刊》和《中国证券报》&#xff0c;它们通常报道财…

从零开始:构建、打包并上传个人前端组件库至私有npm仓库的完整指南

文章目录 一、写组件1、注册全局组件方法2、组件13、组件2 二、测试三、发布1、配置package.json2、生成库包3、配置发布信息4、发布 四、使用1、安装2、使用 一、写组件 1、注册全局组件方法 plugins/index.js const requireComponent require.context(./, true, /\.vue$/…

idea常用配置

IDEA设置全局配置 参考&#xff1a;IDEA设置全局配置_idea如何打开一个项目,全局设置-CSDN博客 idea提交代码到git或svn上时&#xff0c;怎么忽略.class、.iml文件和文件夹等不必要的文件 参考&#xff1a;idea提交代码到git或svn上时&#xff0c;怎么忽略.class、.iml文件和文…

学浪app中的视频怎么缓存

现在越来越多人在学浪app里面购买课程&#xff0c;有的课程有时间限制&#xff0c;想要下载下来&#xff0c;如果你还不知道下载的方法&#xff0c;可以看看我这篇文章&#xff0c;专门讲解如何缓存学浪app里面的课程 讲技术方法很多人可能听不懂&#xff0c;所以我就将技术融…

室友打团太吵?一条命令让它卡死

「作者主页」&#xff1a;士别三日wyx 「作者简介」&#xff1a;CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」&#xff1a;更多干货&#xff0c;请关注专栏《网络安全自学教程》 SYN Flood 1、hping3实现SYN Flood1.1、主机探测1.2、扫描端…

BugKu:Flask_FileUpload

1.打开此题 通过题目知道这个是一个关于Flask的文件上传的漏洞题目 2.查看网页源代码 Flask是一个使用Python编写的轻量级Web应用框架。 这里又提示说用python来运行结果&#xff0c;那很有可能就是要通过python脚本来抓取flag 3.编辑Python脚本 工具&#xff1a;pycharm 文件…