两次写和redo log-程序员宅基地

技术标签: MySQL  两次写  redo log  

两次写特性能加强MySQL的可靠性。在脏页写入到表之前,先将一份副本写入硬盘,成功之后再写入表。

这样做的目的是预防脏页写入表时,发生最坏情况(例如:掉电),导致页损坏。也就是说至少部分数据无法读取。

两次写避免了这个问题。当最坏情况发生,服务重新启动时,系统检测页发生了损坏,那么会读取两次写的副本来恢复损坏的页。这样的系统更加可靠。

redo log是当脏页写入前,先写入到redo日志。当发生掉电时,缓存内的部分脏页会丢失,在系统恢复后,将从redo log中恢复缓存未写入磁盘的数据。

这看起来两者有点相似,再掉电后都有恢复数据的功能。不过两者的功能还是有较大区别。

两次写所存储的数据较小,它的重点是预防马上要写入的数据页,在故障中损坏后的恢复。也就是说重点是修复物理存储介质上损坏的数据页。

redo log重点是故障中,缓存脏页未能写入磁盘的数据,能通过redo log得以完整写入到磁盘。

两者相结合形成了一个完整的可靠的机制。

如果没有二次写,页损坏了,redo log中可能已经不包含这部分内容,数据就不完整了。

如果没有redo log,损坏的页虽然恢复正常,但是缓存脏页未能及时写入的数据则无法找回,数据也不完整。

两者相结合,完整的流程如下:

发生掉电故障后,系统重启恢复。如果检查页受损,那么调用两次写的副本恢复损坏的页。之后读入redo log将未写入的脏页写入到磁盘。

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/bigwood99/article/details/114886351

智能推荐

python post json 解析失败_python - 通过requests.post+URL上传json数据报错[Errno 111] Connection refused...-程序员宅基地

文章浏览阅读1k次。问 题写了一个脚本,抓取Linux服务器信息,然后上传给Django的一个接口,脚本没有错误。print能输出正确信息,接口测试正常,Linux虚拟机操作,Django在pycharm上。脚本片段:hostinfo = {'hostname':hostname,'ip': ip,'osversion': osversion,'memory': memory,'disk': disk,'cpu_co..._pytyon post connection refused

简单记录下支付宝异步回调 notify_url 没有被调用 ,自己的解决方法步骤_请先配置正确的异步回调url-程序员宅基地

文章浏览阅读1.5w次,点赞2次,收藏8次。1、检查下相关配置信息是否写对,特别是异步回调地址、以及支付宝公钥(不是生成的商户应用公钥);2、在支付成功跳转,但异步回调仍然没有被调用,没有接收到数据情况下 登录蚂蚁金服开发平台查看联调日志排查https://openmonitor.alipay.com/acceptance/cloudparse.htm3、查询没看出什么问题的话 就找技术客服支持 帮忙查询 发现是回调地址 ..._请先配置正确的异步回调url

react Cannot read properties of undefined (reading ‘forEach‘)_在react6版本中如何引入etherscannot read properties of unde-程序员宅基地

文章浏览阅读530次。。安装完开发者工具ReactDeveloperTools再运行reac项目报错。下载地址https//www.crx4chrome.com/crx/3068/只需要下载这个ReactDeveloperTools,把之前的停用就好了。项目就可以跑起来了~~_在react6版本中如何引入etherscannot read properties of undefined (reading 'fo

Android 动画 Animator 家族使用指南-程序员宅基地

文章浏览阅读1.3k次。零、前言:本文知识点ValueAnimator的认识与使用估值器TypeEvaluator的自定义与使用插值器TimeInterpolator的自定义与使用Path与Animator的结合使用ObjectAnimator的自定义与使用TimeAnimator的使用AnimatorSet动画集合的使用Animator家族的监听器介绍与使用Animator家族在xml中的使用..._animatorupdatelistener invalidate

eNSP综合实验合集(eNSP综合大作业合集)_可先收藏_ensp的无线网络技术大作业3000字-程序员宅基地

文章浏览阅读10w+次,点赞123次,收藏1.1k次。该文章对eNSP的综合实验做了一个归纳和总结,文章中包含了多个综合实验,可以自由的切换到相应的文章中进行查看_ensp的无线网络技术大作业3000字

【爬虫实战】python文本分析库——Gensim-程序员宅基地

文章浏览阅读2.1k次,点赞25次,收藏37次。Gensim 允许你使用 TF-IDF 权重和其他算法来提取文档中的关键词。当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。_gensim

随便推点

mysql函数function的用法_mysql function-程序员宅基地

文章浏览阅读7.3k次。一、function的用法1.function的创建语法create function 函数名([参数列表]) returns 数据类型begin sql语句; return 值;end;2.用法案例,传入id,查出nameDELIMITER $$CREATE FUNCTION getname1(id VARCHAR(20))RETURNS VARCHAR(200)BEGINDECLARE youname VARCHAR(100);SELECT sname FROM s._mysql function

从头开始编译安装Audacious1.32-程序员宅基地

文章浏览阅读103次。本人特好DIY,这月起开始学习Ubuntu(上个月研究了一下FC6,之所以换用Ubuntu主要问题各位使用过FC的朋友应该都知道。最主要原因是本人家里不能上网。~_~) 今天我们谈谈audacious的编译安装,虽然源里面有现成的deb包,但是版本很低,用起始终感觉不爽,也许是心里作用。下面就把编译过程记录一下,以便以后参考。 编译audacious可把我搞得够呛,不...

Cheat Engine 修改汇编指令_ce用空指令替换原指令-程序员宅基地

文章浏览阅读6.6k次,点赞2次,收藏9次。打开游戏 扫描阳光 扫描过程就不讲了 找到阳光的地址 显示反汇编 找到使阳光减少的反汇编代码 空指令替换 将阳光减少汇编指令,用空指令替换,这样阳光就不再减少了 ..._ce用空指令替换原指令

9.10 中国电信it研发中心 笔试编程题_中国电信计算机类试卷有编程吗-程序员宅基地

文章浏览阅读1.3w次,点赞6次,收藏37次。A 题意: 假设字符串中出现次数最少的字母是x, 出现次数为y, 删除所有出现次数为y的字符 思路: 统计一下字符的出现次数, 然后照着做就行#include <iostream>#include <algorithm>#include <string>#include <cmath_中国电信计算机类试卷有编程吗

数据库的分类_relative database relation database-程序员宅基地

文章浏览阅读88次。关系型数据库(RDBMS:relative database manager system)特点:(1) 表与表之间有关系(2) 有行有列(和excel类似)(3) 是通过SQL语句去操作数据库。比较有名代表:Mysql:免费,开源。Oracle:甲骨文,收费,大型公司,一年费用9位数SQL Server:微软公司,可以安装WindowsDB2非关系型数据库(no-sql)特点:(1) 表与表之间没有关系(2) 通过API(Java、PHP、Python代码)去操作(3) 充分使_relative database relation database

RxJAVA-Single_rxjava single-程序员宅基地

文章浏览阅读960次。interface SingleObserver<T> { void onSubscribe(Disposable d); void onSuccess(T value); void onError(Throwable error);}订阅者一共三个方法可以处理。给出示例package com.netty.demo.vertx;import io.reactivex.*;import io.reactivex.disposables.Disposab._rxjava single

推荐文章

热门文章

相关标签