热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle之RMAN备份及还原

RMAN可以进行增量备份:数据库,表空间,数据文件只有使用过的block可以被备份成backupset表空间与数据文件对应关系:dba_dat

RMAN可以进行增量备份:数据库,表空间,数据文件 只有使用过的block可以被备份成backup set 表空间与数据文件对应关系:dba_dat

RMAN可以进行增量备份:数据库,表空间,数据文件

只有使用过的block可以被备份成backup set

表空间与数据文件对应关系:dba_data_files / v$datafile_header

在noarchivelog模式下,可以使用RMAN备份read-only和offline的表空间

Oracle RMAN停机备份:

备份

RMAN连接上ORACLE,WINDOWS下在命令模式下

RMAN TARGET /

连接本地数据库用的是本地认证模式。RMAN连接数据库必须在dedicate模式下。因此在share模式下的数据库应配置一个dedicate的连接用于RMAN连接。

如果要把控制文件、参数文件也一起备份

configure controfile autobackup on;//打开autobackup
configure controfile autobackup off;//关闭autobackup
关闭数据库
RMAN>shutdown immediate
mount 数据库RMAN的备份必须在MOUNT模式下,这也就是控制文件备份的重要。
RMAN>startup mount
最简单的备份
RMAN>backup database
就这一句就OK了
这样的备份,备份集在数据库默认位置。%oracle_home%/ora92/database
当然你也可以用run来灵活的定义你的备份。
RMAN>run{
>allocate chennel d1 type disk; //分配通道
>backup full database //全备份数据库
>include current controlfile //包括当前的controlfile
>format 'e:\oracle\orders\db_%d_%s_%p_%t_%T'; //备份文件位置和文件名格式
>release channel d1;//释放通道
>}

恢复
1、数据文件损坏,而控制文件是好,或者已经恢复
RMAN连上数据库
startup mount
restore database
recover database noredo;
alter database open resetlogs;
recover database noredo该命令指示RMAN执行最后的恢复操作以准备打开这个数据库。因为是在NOARCHIVELOG模式下并且不应用任何归档的重做日志并且丢失了联机重做日志,所以要求在这条命令中使用noredo参数。

最后使用alter database open resetlogs打开数据库。由于已经还原了控制文件并且需要重新构建重做日志,,所以必须用resetlogs。
2、还原控制文件
startup nomount;
set dbid =
restore controlfile from autobackup ;
alter database mount;
restore database;
recover database noredo;
alter database open resetlogs;
alter database open;
在这个例子中有一个DBID这个可以
select * from v$database中查到。但是一个数据库在控制文件坏掉了不能OPEN如何能看的到呢这就在平时把这个DBID记下来。
这是最简单的用RMAN备份与恢复的例子,但从中可以看到RMAN备份与恢复的梗概。

ORACLE RMAN在线备份:

1. ORACLE RMAN在线备份之前需要切换日志方式为归档日志;

a. 关闭数据库
SQL> shutdown immediate;

b. 启动数据库到mount状态
SQL> startup mount;

c. 启用归档模式
SQL> alter database archivelog;

d. 查看修改后的数据库备份和恢复策略及归档文件的位置
SQL> archive log list;

注意:修改成archive模式之后,之前所有的数据库备份均无效。

e. 修改相应的初始化参数
Oracle10g之前,你还需要修改初始化参数使数据库处于自动归档模式。
可用SQL> show parameter log_archive_start;查看
NAME TYPE VALUE
------------------------------------ ----------- --------------
log_archive_start boolean FALSE
SQL> alter system set log_archive_start=true scope=spfile;
重启数据库此参数生效,此时数据库处于自动归档模式。

当然你也可以不做第5步,直接
SQL>archive log start
使数据库启用自动归档,但是重启后数据库仍然处于手工归档模式。

2. 运行:RMAN target /

3. RMAN信息保存:默认保存在control file中,保存周期7天

调整:alter system set control_file_record_keep_time=天数;

4. 搭建独立数据库保存RMAN备份信息

由于只有一个数据库,就建在本身数据库上

a. 创建表空间RC:create tablespace rc datafile size 10M autoextend on next 1M

b. 创建用户RC:

CREATE USER rc IDENTIFIED BY rc TEMPORARY TABLESPACE temp DEFAULT TABLESPACE rc QUOTA UNLIMITED ON rc;

c. 授权RC: GRANT RECOVERY_CATALOG_OWNER TO rc;

d. 搭建:

rman catalog

RMAN>create catalog;

RMAN>exit

rman target / catalog

RMAN>register database;

e. 使用:

rman target / catalog

这种连接方式后,数据就会在控制文件和catalog各存一份

5. 全局参数配置:

查看:show all;

修改:configure 参数名称 具体设置

例如:修改是否自动保存control file:configure controlfile autobackup on;

恢复默认值:configure 参数名称 clear;

关键参数:

a. 保存周期:retention policy

默认是redundancy 1:保留一个备份;

可用值:recovery window of 7 days:保留可以满足7天恢复周期的备份

根据条件检查:report obsolete:RMAN会根据保存周期参数来列出可以删除的备份

删除多于备份:delete obsolete

b. 优化备份:backup optimization:RMAN会自动忽略已经备份过的内容(数据文件,归档日志,备份块)

前提:备份指定同一个channel

c. 默认备份渠道:default device type to disk:默认备份到磁盘,路径为flash recovery area

渠道类型:

disk:文件系统路径

flash recovery area:默认路径

sbt:磁带设备

修改到磁盘其他路径:configure channel device type disk format '路径/%U';

例如:configure channel device type disk format '/tmp/movedata/%U';

6. 备份结果

backupset:backup (as backupset) 备份内容,里面分割成一个或多个backup piece,只有该类型备份可以进行压缩。

copy:backup as copy 备份内容

按类型查看:

backupset 查看:list backup summary(list backupset summary)

查看详情:list backupset BS

copy查看:list copy

按内容查看:

整个数据库:list backup of database;

tablespace:list backup of tablespace users;

数据文件:list backup of datafile n;

控制文件:list backup of controlfile;

归档日志:list archivelog all;

按规则查看:

查看根据保存规则可删除文件:report obsolete;

查看根据保存规则需要备份内容:report

RMAN和OS结合检查:corsscheck 内容;

7. 备份方式

full:全备;

Incremental:增量备份

可以增量备份的类型:数据库,数据文件,表空间

a. 首先需要做level 0备份作为基础。例如:backup incremental level 0 备份内容;(备份内容:所有使用过的data block,和image copy不同)

b. 增量类型:

累计增量:backup cumulative level 1 备份内容;

差异增量:backup incremental level 1 备份内容;

区别:累计增量始终是基于level 0的备份;

第一次差异增量是基于level 0的备份;从第二开始就是基于前一次增量备份

c. Image备份增量方式:

第一次:以Image全备为基础;

第二次:基于全备,做增量备份;完成后合成成一个Image全备

第三次:基于第二次的Image全备,做增量备份;完成后合成成一个Image全备

实现:

例如:针对tablespace example

RUN {
RECOVER COPY OF tablespace example WITH TAG 'incr_update';
BACKUP INCREMENTAL LEVEL 1 FOR RECOVER OF COPY WITH TAG 'incr_update'
tablespace example;
}

d. 开启参数"block change tracking",可以提高速度

查看状态:SELECT status FROM v$block_change_tracking;

默认值:DISABLED

开启:ALTER DATABASE ENABLE BLOCK CHANGE TRACKING;(默认存放路径OMF中的DB_CREATE_FILE_DEST)

设置文件路径:

ALTER DATABASE ENABLE BLOCK CHANGE TRACKING USING FILE '/u01/oradata/MYSID/rman_change_track.f' REUSE;

关闭:ALTER DATABASE DISABLE BLOCK CHANGE TRACKING;

备份并检查:bakcup check logical 备份内容;

不备份只是检查文件:backup validate 备份内容;

如果检查有报错,查看:v$backup_corruption;v$copy_corruption

8. 备份内容:

整个数据库:RMAN>backup database;

经典整库备份:backup as compressed backupset database include current controlfile plus archivelog delete input;

tablespace:RMAN>backup tablespace 名字;

数据文件:RMAN>backup datafile n; (n:具体的数据文件编号select file_name,file_id,tablespace_name from dba_data_files;)

控制文件:RMAN>backup current controlfile;

或者RMAN>backup database include current controlfile;

日志文件:RMAN>backup archivelog all;

或者RMAN>backup database plus archivelog;

参数文件:RMAN>backup spfile;

9. 还原

a. 完全恢复

方法一:从最近的备份集恢复整个数据库,数据库会自动运行redo和archive日志(完全恢复):

SQL>shutdown immediate

SQL>startup mount

RMAN>restore database;

RMAN>recover database;

RMAN>sql 'alter database open';

方法二:从tag恢复整个数据库,数据库也会运行redo 和archive 日志(完全恢复),结果与上面的脚本一样:

1. 查看标签:

推荐阅读
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了HTML中标签的使用方法和作用。通过具体示例,解释了如何利用标签为网页中的缩写和简称提供完整解释,并探讨了其在提高可读性和搜索引擎优化方面的优势。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
author-avatar
_我是谁谁谁__950
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有