Oracle增量更新备份(更快的备份策略)

2024-03-12 13:44

本文主要是介绍Oracle增量更新备份(更快的备份策略),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

正常的备份策略包括:全库备份,full备份,创建镜像备份,累积增量备份以及差异增量备份:

 

全库备份:如名,对oracle整个数据库进行备份,包括archivedlog,数据文件,控制文件,参数文件。

示例:

e2bd9c0834f049cb8c1f99595211272f.png

 

full备份:backup databse命令默认是一个full 备份,(注意:full备份不备份归档日志)

39ee9994c77a4dcaa6d96523533e92c6.png

 

创建镜像备份:也可以使用rman创建你需要备份的文件的完全镜像,并指定一个目录来存放它,镜像文件可以认为是 所需备份文件的完全复制,文件大小是相同的。

例如:BACKUP AS COPY DATAFILE '/ORADATA/users_01_db01.dbf';

累积增量备份和差异增量备份有何区别?

下面两张图可以很好的诠释  累积增量备份和差异增量备份的区别:

差异增量备份:

c11f5bd6d97c4f4080f59bcb859232f1.png

累积增量备份:

393c961580b0408bb868bb63dfed1e61.png

如果我们在周日这一天做了0级全备(注意0级全备 与 full 备份是有差异的,0级备份可以做为1级备份的参照,full备份不可以,但在备份内容上,0级备份与full备份备份的内容相同)。

周一做了2级备份。

在周二这天,如果我们做了2级备份,如果我们是差异增量备份,本次2级备份会找n级或n-1级备份。在图中周二这一天可以参照周一同级的2级备份,所需要备份的内容为周一到周二这一天的内修改的内容。

如果我们是累积增量备份,则只会找n-1级备份,没有n-1级备份再找n-2级备份。图中周二的2级备份只会找1级备份,1级找不着就会找0级备份。

能不能更快?

增量更新备份:

我们可以这样做,先做一个0级备份,之后每一天都做一次一级备份,再把这个一级备份所修改的内容,每天都应用于这个0级备份,这样这个0级备份每天都是全新的。

示例:

1、第一次执行命令,会创建一个完整的备份(这个1级备份因为是第一次执行,前面没有0级备份,所以本次1级备份就是一次0级备份)。

backup incremental level 1 for recover of copy with tag 'daily_inc' database;

040f495cb3e446e88bb58aee4eecc792.png

 

 

2、此时如果做recovery,是没有动作,因为没有增量备份

recover copy of database with tag 'daily_inc';

d84a3d887bab491d9e2a132723dc0b8d.png

3、再次执行,产生增量备份,文件存放在指定的format路径下

backup incremental level 1 for recover of copy  with tag 'daily_inc' database;

906d453b7b7041a99be5f1dd836f5d3e.png

4、此时会应用增量备份进行recovery

recover copy of database with tag 'daily_inc';

0053e49fd561477a87fdb28afabeeea6.png

5、list copy和list backup都会出现相应的内容。

8afdd4e2adf443e7a9f14118fcb60f07.png

 

能不能更快?

 

打开块移动跟踪(Monitoring Block Change Tracking):

67515399fe3c44498dd7d671012ec5dd.png

速度超级快。

fd7959390bc14ee48c10c5e7d9909334.png

使用快移动跟踪后瞬间完成,因为它仅需要查找被修改的块,避免了全表扫描。

 

 

 

这篇关于Oracle增量更新备份(更快的备份策略)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/801450

相关文章

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

GIS图形库更新2024.8.4-9.9

更多精彩内容请访问 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信:digital_twin123 Cesium 本期发布了1.121 版本。重大新闻,Cesium被Bentley收购。 ✨ 功能和改进 默认启用 MSAA,采样 4 次。若要关闭 MSAA,则可以设置scene.msaaSamples = 1。但是通过比较,发现并没有多大改善。

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla