当前位置: 首页 > news >正文

【赵渝强老师】Oracle RMAN的目录数据库

在这里插入图片描述

在默认情况下,Oracle RMAN将备份时产生的元信息保存到控制文件中。RMAN在执行恢复时,就需要读取控制文件,从而找到备份的信息来完成数据库的恢复。因此,如果控制文件发生了丢失和损坏将导致数据库无法执行恢复。另一方面随着备份的不断增多,也会导致控制文件的大小无限增长。为了更好地管理RMAN备份的元信息,Oracle可以使用一个专门的备份信息存储地来存储这些信息,这就是RMAN的目录数据库(Catalog Database)。如果RMAN备份的目标数据库已经注册到了目录数据库中,当执行备份是时Oracle就会使用目录数据库来取代控制文件存储RMAN备份时产生的元信息。

视频讲解如下

【赵渝强老师】Oracle RMAN的目录数据库

在RMAN的备份过程中,使用目录数据库具有以下的优点:

  • 取代控制文件用于存储RMAN备份的元信息。
  • 可以存储更长的备份历史记录。
  • 可以被多个目标数据库共享。
  • 可以存储RMAN的脚本。

下图展示了目标数据库和目录数据库之间的关系。
在这里插入图片描述

在了解到了什么是目录数据库后,下面将通过具体的操作步骤来创建一个目录数据库,并完成将目标数据库注册到目录数据库中。
《Oracle数据库从零开始》

(1)使用Oracle DBCA创建一个新的数据库作为目录数据库使用。目录数据库的名称设置为rcat。如下图所示。
在这里插入图片描述

(2)登录目录数据库,创建RMAN存储备份信息的表空间。

sqlplus sys/password@rcat as sysdba
SQL> create tablespace rcat_tbs datafile '/home/oracle/rcat_tbs01.dbf' size 50M;

(3)给目录数据库创建用户,并为用户授权能够使用rcat_tbs表空间。

SQL> create user c##rcat_owner identified by password;
SQL> alter user c##rcat_owner default tablespace rcat_tbs;
SQL> alter user c##rcat_owner quota unlimited on rcat_tbs;
SQL> grant recovery_catalog_owner to c##rcat_owner;

(4)使用RMAN并以rcat_owner用户进行登录登录,并输入用户的密码。

rman catalog c##rcat_owner@rcat

(5)创建目录数据库所需要的表。

RMAN> create catalog;

(6)验证创建的目录数据库表

sqlplus c##rcat_owner/password@rcat
SQL> select * from tab;# 输出的信息如下:
TNAME			       TABTYPE	      CLUSTERID
------------------------------ ------------- ----------
AL				       TABLE
BCB			       TABLE
BCF			       TABLE
BCR			       TABLE
BDF			       TABLE
BP				       TABLE
BRL			       TABLE
BS				       TABLE
BSF			       TABLE
CCB			       TABLE
CCF			       TABLE
CDF			       TABLE
CFS			       TABLE
CKP			       TABLE
CONF				  TABLE
......... 

(7)使用RMAN连接目标数据库和目录数据库,并将目标数据库注册到目录数据库中。

rman target / catalog c##rcat_owner@rcat
RMAN> register database;# 输出的信息如下:
database registered in recovery catalog
starting full resync of recovery catalog
full resync complete

(8)登录目录数据验证目标数据库的注册信息。

sqlplus c##rcat_owner/password@rcat
SQL> select db_id,reg_db_unique_name from db;# 输出的信息如下:DB_ID 		REG_DB_UNIQUE_NAME
------------------ ------------------------------
1618358864 		ORCL

(9)在RMAN中执行一个简单的备份。

rman target / catalog c##rcat_owner@rcat
RMAN> backup datafile 7;

《Oracle数据库从零开始》

(10)登录目录数据库检查目录数据库中的RMAN的备份信息。

SQL> select db_name,file#,backup_type from rc_backup_datafile;# 输出的信息如下:
DB_NAME    FILE#  BACKUP_TYPE
----------------- ----------- ------------------------
ORCL		  7   	D

从输出的信息可以看出,RMAN在执行备份时将备份的元信息写入了目录数据库中。

http://www.dtcms.com/a/267340.html

相关文章:

  • Cookie(搭配domain)/Session(搭配HttpServletRequest+HttpSession)
  • python优先队列使用
  • 基于spark的奥运会奖牌变化数据分析
  • mysql的备份与恢复(使用mysqldump)
  • MyChrome.exe与Selenium联动避坑指南:User Data目录冲突解决方案
  • 爬虫-web请求全过程
  • 数据结构:数组:二分查找(Binary Search)
  • C#使用开源框架NetronLight绘制流程图
  • Hinge×亚矩云手机:以“深度连接”为名,重构云端社交的“真实感”
  • AI 正在深度重构软件开发的底层逻辑和全生命周期,从技术演进、流程重构和未来趋势三个维度进行系统性分析
  • Jedis 原生之道:Redis 命令 Java 实现指南(二)
  • SpringAI与智能体入门
  • 探索 Ubuntu 上 MongoDB 的安装过程
  • NX二次开发常用函数——获取边对应的面 UF_MODL_ask_edge_faces
  • 使用 C++/Faiss 加速海量 MFCC 特征的相似性搜索
  • 电脑休眠设置
  • 【网络与爬虫 13】智能伪装:Scrapy-Fake-UserAgent反检测技术实战指南
  • springboot中使用线程池
  • 【Elasticsearch】检索排序 分页
  • 20. 有效的括号
  • BUUCTF在线评测-练习场-WebCTF习题[网鼎杯 2020 青龙组]AreUSerialz1-flag获取、解析
  • 【Flask】flask中get方法和post方法区别
  • CMake基础:条件判断详解
  • openai和chatgpt什么关系
  • 单用户模式、紧急模式、救援模式有什么区别
  • 动手学深度学习-学习笔记【二】(基础知识)
  • 若 VSCode 添加到文件夹内右键菜单中显示(通过reg文件方式)
  • 在 Windows 上安装和运行 Apache Kafka
  • Android Input 系列专题【事件的读取与分发】
  • 在SSM+vue项目中上传表单数据和文件