首页 > 数据库 >oracle 备份与恢复常见的七大问题

oracle 备份与恢复常见的七大问题

时间:2024-05-14 21:08:28浏览次数:19  
标签:逻辑 恢复 备份 七大 oracle 数据 数据库

为了最大限度保障数据的安全性,同时能在不可预计灾难的情况下保证数据的快速恢复,需要根据数据的类型和重要程度制定相应的备份和恢复方案。

在这个过程中,DBA的职责就是要保证数据库(其它数据由其它岗位负责)的高可用和高性能,以下典型问题及解答可供参考。

1、Oracle的几种备份方式简介

备份就是把数据库复制到转储设备的过程。其中,转储设备是指用于放置数据库副本的磁带或磁盘,备份是一份数据副本。

从物理与逻辑的角度来看,备份可以分为物理备份和逻辑备份。


物理备份:
对数据库操作系统的物理文件(数据文件,控制文件和日志文件)的备份。物理备份又可以分为脱机备份(冷备份)和联机备份(热备份),前者是在关闭数据库的时候进行的,后者是以归档日志的方式对运行的数据库进行备份。可以使用oracle的恢复管理器(RMAN)或操作系统命令进行数据库的物理备份。


逻辑备份:
对数据库逻辑组件(如表和存储过程等数据库对象)的备份。逻辑备份的手段很多,如传统的EXP,数据泵(EXPDP),数据库闪回技术等第三方工具,都可以进行数据库的逻辑备份。

从数据库的备份角度,备份可以分为完全备份和增量备份和差异备份。

  • 完全备份:每次对数据库进行完整备份,当发生数据丢失的灾难时,完全备份无需依赖其他信息即可实现100%的数据恢复,其恢复时间最短且操作最方便。
  • 增量备份:只有那些在上次完全备份或增量备份后被修改的文件才会被备份。优点是备份数据量小,需要的时间短,缺点是恢复的时候需要依赖以前备份记录,出问题的风险较大。
  • 差异备份:备份那些自从上次完全备份之后被修改过的文件。从差异备份中恢复数据的时间较短,因此只需要两份数据—最后一次完整备份和最后一次差异备份,缺点是每次备份需要的时间较长。

2、Oracle数据库备份采用哪种备份方式?适用范围分别是什么?

RMAN是oracle推荐的数据保护工具,在备份恢复上,RMAN能够借助备份数据恢复一段时间范围内某个时间点数据库的状态。此外RMAN在备份恢复的校验上更加严格,最大程度保护数据的完整性、一致性以及适用性,同时也方便备份恢复的统一管理。

EXP/EXPDB,在oracle的定位中,只是一个数据迁移的手段。在备份恢复上,数据泵只能利用备份数据来恢复一个时间点上的数据库状态,无法借助备份数据在一段时间内自由选择恢复点。在严格的意义说,数据泵备份并不能说是一种有效的数据保障措施,这更像是一种临时的保底操作。

集中化备份管理来说,rman是最有效也是最可靠的方式。数据泵虽然操作简单,对于数据的持续性保护太弱了。

结合系统的特点,逻辑导出和RMAN配合使用效果最佳。

3、数据库的备份与恢复的时间窗口?需要做都那些方面的考虑?

需要着重考虑几点:

1、备份方式:一般都是FULL+INCR。

2、备份时间窗口:备份的过程中对生产业务(数据库)压力是很大的,所以首先应该规划备份的时间窗口,一般都在晚上。

3、备份流量路径:确定了备份时间窗口,就想想备份的流量怎么走。确定好流量路径,不要影响其他业务。

4、数据保留、克隆:对于重要的数据,不仅需要备份,最好克隆一份。

恢复一般在单独的恢复环境。恢复验证周期,一般一个季度内至少挑选各类型备份恢复一次。

4、Rman备份保留天数和保留副本数,这两种具体有什么区别,在什么场景下使用什么样的参数设置?

Configure retention policy to recovery window of N days;--表示备份保留N天,即表示oracle可以保证还原到N天内的任意时间点。
CONFIGURE RETENTION POLICY TO REDUNDANCY n--表示备份保留N份。

保留天数主要考虑的方面是:想要把数据库恢复到历史的哪一个时间点;保留副本主要考虑的方面是:要针对备份如何做冗余。

区别就是基于恢复窗口的保留策略纬度不同,看业务的具体需求。

5、在三地两中心的双活结构中,数据库还有备份的必要性吗?

数据库双活了更需要数据库备份,否则数据库逻辑错误,一损俱损。多活只能保障单边故障下业务还可以online(高可用),但对于数据逻辑错、历史数据审查、历史数据分析等问题,多中心多活的结构框架依旧无法克服。

6、在备份和恢复中,Catalog的主要优势在哪?


rman的备份信息默认是存放在目标数据库的控制文件中的,存放时间由control_file_record_keep_time参数控制,默认是7天。

也可以把rman的备份信息保存到一个独立的数据库中,叫做recovery catalog,使用recovery catalog可以保存更长时间的备份信息,如果想要试用永久保留备份的话,必须使用catalog。

如果只是简单的备份管理需求的话,建议使用控制文件即可。

7、Oracle11g数据库数据量有50T,每天增量50g左右,该如何制定备份方案,如何验证备份的有效性?


以一次全备份来算,在12h内备份完成,那么平均备份速度最低是5010241024/12/3600=1210MB/S

按照LTO 5 drive的速度(140MB/S)来算,备份最低的drive数量:1210/140=9

为了保障dive尽量保持最大IO,建议额外关注几点:

1、datafile较小的话,聚合成较大的bakcup piece;
2、调整read/write blocksize减少读写次数,可酌情调整至MB大小;
3、调整备份脚本,一个channel对应一个backup session,每个channel尽量保障只有一个大块backup piece写入;
4、关闭备份软件和drive的多路复用功能,保证每个dive上只有一个session写入;
5、备份尽量走单独的HBA卡,不要和业务或存储共用。

标签:逻辑,恢复,备份,七大,oracle,数据,数据库
From: https://www.cnblogs.com/gdjgs/p/18192265

相关文章

  • Oracle RAC备库启动service报"ORA-16000: database open for read-only access"
     OracleRAC备库启动service报"ORA-16000:databaseopenforread-onlyaccess" 还是2019.03.01那天的事了,当时在KFT客户就遇到这个问题,最近在规整一些资料看到当时待整理的文档,就抽空做做实验整理下。报错信息如下,ADG备库:[oracle@xxxprdoradb01~]$srvctlstartservic......
  • AutoMySQLBackup加密备份解密问题浅析
    AutoMySQLBackup备份配置了加密选项过后,它会将数据库的备份文件加密。测试解密这些加密的备份文件时遇到错误(密钥做了脱敏处理)。$ openssl enc -aes-256-cbc -d -in  daily_mysql_2024-05-14_09h09m_Tuesday.sql.gz.enc \>   -out daily_mysql_2024-05-14_09h09m_T......
  • Oracle:谈谈service_names和dbms_service的一点问题
     Oracle:谈谈service_names和dbms_service的一点问题 services_name在在19C中官方明确提到已经弃用了,只保留兼容,且在未来版本中可能不再支持该初始化参数。传送门。其次,无论是在12C或者11G,官方都表明了OracleRAC或者OracleRestart环境下,不通过直接修改services_name参数,而......
  • oracle 备份与恢复常见的七大问题
    为了最大限度保障数据的安全性,同时能在不可预计灾难的情况下保证数据的快速恢复,需要根据数据的类型和重要程度制定相应的备份和恢复方案。在这个过程中,DBA的职责就是要保证数据库(其它数据由其它岗位负责)的高可用和高性能,以下典型问题及解答可供参考。1、Oracle的几种备份方式简介......
  • Oracle释放表高水位线(HWM)的j几种方法
    转自:https://blog.csdn.net/loveLAxin/article/details/1293570831.表高水位线概述:高水线(HWM)是数据块未格式化且从未使用过的数据段中的点。也就是说高水位线存在于段。查询表数据时,会扫描高水位线下的所有数据块。(包括删除以后不存在数据的块)原则上高水位线只会增大,不会缩小......
  • Oracle-HWM(High Water Mark) 高水位解读
    转自:https://cloud.tencent.com/developer/article/1861861Oracle的逻辑存储管理ORACLE在逻辑存储上分4个粒度,由大到小为:表空间,段,区和块.块Block块:是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是说当ORACLE从数据文件读数......
  • 备份恢复数据库
    #备份数据并且恢复数据#备份数据,要在DOS下执行mysqldump指令,这个指令其实在mysql安装目录\bin#这个备份的文件,就是对应的sql语句mysqldump-uroot-p-Bhsp_db02hsp_db03>d:\\bak.sqlDROPDATABASEhsp_db03;#恢复数据(注意:在DOS下进去mysql在执行)sourced:\\bak.sql#......
  • Oracle Index Clustering Factor(集群因子)
    转自:https://www.cnblogs.com/Richardzhu/articles/2874972.html一、本文说明:   今天在做测试的时候发现字段上有索引,但是执行计划就是不走索引,经过在网上查找才发现原来是索引的集群因子过高导致的。本文属于转载。二、官网说明    Theindexclusteringfactormeas......
  • Oracle 恢复之using backup controlfile 和 until cancel
    1、recoverdatabase/tablespace/datafileOracle以当前控制文件记录的SCN为恢复终点,将相关的datafile恢复到当前控制文件记录的SCN。控制文件不能比数据文件更旧。完全恢复,利用归档日志和在线重做日志。2、recoverdatabaseuntilcancel只能在sqlplus工具内执行。在丢失日......
  • openGauss 逻辑备份与恢复
    逻辑备份恢复gs_dumpgs_dumpallgs_restore详情查看:https://opengauss.org详情查看:https://docs-opengauss.osinfra.cn......