OCP读书笔记(3) - 使用RMAN恢复目录
创建恢复目录
在hndx上创建恢复目录:
[oracle@oracle admin]$ export ORACLE_SID=hndx
[oracle@oracle admin]$ sqlplus / as sysdba
SQL> create tablespace rman_cata datafile '/u01/app/oracle/oradata/hndx/cata01.dbf' size 10M;
SQL> create user rman_cata default tablespace rman_cata identified by oracle;
SQL> grant connect,resource,recovery_catalog_owner to rman_cata;
SQL> exit
[oracle@oracle admin]$ echo $ORACLE_SID
hndx
sqlplus rman_cata/oracle
select * from tab--没有对象
[oracle@oracle admin]$ rman catalog rman_cata/oracle
RMAN> create catalog;
sqlplus rman_cata/oracle
select * from tab;--发现有上100个对象
[oracle@oracle admin]$ rman target sys/oracle@orcl catalog rman_cata/oracle@hndx
RMAN> register database;--将目标数据库的信息注册到恢复目录数据库
手动添加备份元数据
SQL> alter tablespace users begin backup;
SQL> !cp -v /u01/app/oracle/oradata/orcl/users01.dbf /u01/backup/hotbk/users.bak
SQL> alter tablespace users end backup;
RMAN> catalog datafilecopy '/u01/backup/hotbk/users.bak' ;
RMAN> list copy of tablespace users;
RMAN> change datafilecopy '/u01/backup/hotbk/users01.dbf' uncatalog;--从控制文件的元数据中删除此项
RMAN> list copy of tablespace users;
RMAN> catalog datafilecopy '/u01/backup/hotbk/users01.dbf' tag=users;--注册的同时进行标记
VPC(Virtual Private Catalog)
假如有3个数据库,数据名分别为:orcl,orcl1,orcl2,创建一个catalog服务器orcl,同时为2台数据库提供服务
要求每个数据库dba只能看到自己的元数据
首先,需要创建一个包含所有目标数据库的基础目录,假设拥有者为:RMAN
1. 创建表空间:
create tablespace rman_tbs datafile '/u01/app/oracle/oradata/orcl/rman_tbs01.dbf' size 100M;
2. 创建RMAN用户:
create user rman default tablespace rman_tbs identified by oracle;
grant recovery_catalog_owner to rman;
3. 创建恢复目录:
rman catalog rman/oracle
create catalog;
4. 将orcl1和orcl2的信息注册到恢复目录:
export ORACLE_SID=orcl1
rman target / catalog rman/oracle@orcl
register database;
export ORACLE_SID=orcl2
rman target / catalog rman/oracle@orcl
register database;
现在无无论orcl1和orcl2的dba都能考到对方的数据,这是不安全的,如:
export ORACLE_SID=orcl1
rman target / catalog rman/oracle@orcl
list db_unique_name all;
为了安全,不让对方dba看到自己的数据,可以创建虚拟专用目录,如:
1. 创建虚拟专用目录的所有者:
create user orcl1 default tablespace users identified by oracle;
create user orcl2 default tablespace users identified by oracle;
2. 为虚拟专用目录的所有者受权:
export ORACLE_SID=orcl
sqlplus / as sysdba
grant recovery_catalog_owner to orcl1;
grant recovery_catalog_owner to orcl2;
rman catalog rman/oracle
grant catalog for database orcl1 to orcl1;
grant register database to orcl1;
grant catalog for database orcl2 to orcl2;
grant register database to orcl2;
3. 创建虚拟专用目录:
export ORACLE_SID=orcl1
rman target / catalog orcl1/a@orcl
create virtual catalog;
list db_unique_name all;
只能看到自己的数据
export ORACLE_SID=orcl2
rman target / catalog orcl2@orcl
create virtual catalog;
list db_unique_name all;
只能看到自己的数据
合并恢复目录
1. 删除以上实验的恢复目录,在orcl和orcl1上重新创建各自的catalog
export ORACLE_SID=orcl1
rman target / catalog orcl1/oracle@orcl
unregister database;
export ORACLE_SID=orcl2
rman target / catalog orcl2/oracle@orcl
unregister database;
export ORACLE_SID=orcl
rman target / catalog rman/oracle
drop catalog;
2. 重新创建catalog:
export ORACLE_SID=orcl
rman catalog rman/oracle
create catalog;
connect target /
register database;
list db_unique_name all;
3. 为orcl1创建自己的catalog:
export ORACLE_SID=orcl1
sqlplus / as sysdba
create user rman1 default tablespace users identified by oracle;
grant connect,resource,recovery_catalog_owner to rman1;
rman catalog rman1/oracle
create catalog;
connect target /
register database;
list db_unique_name all;
4. 将orcl1的恢复目录合并到orcl中:
export ORACLE_SID=orcl
rman target / catalog rman/oracle
import catalog rman1/oracle@orcl1;
list db_unique_name all;
发现orcl1已经合并到orcl中
export ORACLE_SID=orcl1
rman target / catalog rman1/oracle
list db_unique_name all;
发现为空
-------------------------------------------------------------------------
恢复目录
createa tablespace cata_tbs datafile '/u01/app/oracle/oradata/orcl/cata_tbs01.dbf' size 100M; -- no less than 15M
create user cata default tablespace cata_tbs identified by oracle;
grant connect,resource,recovery_catalog_owner to cata;
sqlplus cata/oracle
select * from tab;
rman catalog cata/oracle;
create catalog;
rman target / catalog cata/oracle;
register database;
backup database;
怎么在恢复目录中注册数据库
rman target sys/oracle@orcl1 catalog cata/oracle@orcl
register database;
unregister database;
注册额外的备份文件
rman> catalog backuppiece 'file_name';
alter tablespace users begin backup;
!cp -v /u01/app/oracle/oradata/orcl/users01.dbf /u01/app/oracle/backup/hotbk
alter tablespace users end backup;
catalog datafilecopy '/u01/app/oracle/backup/hotbk';
list copy of database;
重新同步控制文件和恢复目录
rman>resync catalog;
使用rman存储脚本
CREATE [GLOBAL] SCRIPT script_name FROM FILE 'file_name';
rman target / catalog cata/oracle;
create script backupdb {backup database format='/u01/app/oracle/imanbk/%d_%s.dbf';}
run{execute script
script name;
}
RUN { EXECUTE GLOBAL SCRIPT
script_name
; }
print script scriptname;
print script backdb to file '/u01/app/oracle/rmanbk.sh';
rman> list script names;
rman> replace script backdb
{delete noprompt backup;
backup database plus archivelog;
}
list script names;
print script backdb;
OCP读书笔记(3) - 使用RMAN恢复目录的更多相关文章
- OCP读书笔记(7) - 使用RMAN执行恢复
7.Using RMAN to Perform Recovery 使用RMAN进行完全恢复system表空间文件丢失的恢复 模拟损坏: SQL> conn /as sysdba; SQL> ...
- OCP读书笔记(5) - 使用RMAN创建备份
5.Creating Backups with RMAN 创建备份集 RMAN> backup as backupset format '/u01/app/oracle/backup/rmanb ...
- RMAN恢复目录
是否使用RMAN恢复目录(Recovery Catalog 你可能从其他人或书上听过RMAN恢复目录(也有可能是其他名字,RMAN Recovery Catalog的翻译较多较杂,以下简称恢复目录), ...
- RMAN_学习笔记5_RMAN Catalog Script恢复目录脚本
2014-12-24 Created By BaoXinjian
- Oracle DB 使用RMAN恢复目录
• 对恢复目录和RMAN 资料档案库控制文件的使用进行比较• 创建和配置恢复目录• 在恢复目录中注册数据库• 同步恢复目录• 使用RMAN 存储脚本• 备份恢复目录• 创建虚拟专用目录 RMAN 资料 ...
- rman catalog (rman 恢复目录)
受控制文件大小的限制,一般rman需要用rman catalog来管理及存放备份信息: 这里介绍一下创建rman catalog的步骤: C:\Documents andSettings\Admini ...
- OCP读书笔记(8) - 监控和调优RMAN
监视RMAN作业 1. 创建rman备份: RMAN> run { allocate channel ch1 type disk; allocate channel ch2 type disk; ...
- OCP读书笔记(6) - 手动恢复操作
6.Restore and Recovery Task 非关键性文件丢失的恢复 临时文件丢失的恢复 临时表空间文件丢失的恢复: 查看数据库中的临时文件: SQL> select file#,ST ...
- OCP读书笔记(2) - 配置恢复
RMAN的命令类型 1. sqlplus命令 [oracle@oracle admin]$ export ORACLE_SID=orcl [oracle@oracle admin]$ rman tar ...
随机推荐
- linux登录windows服务器
在公司同时也兼顾了王老师会议网站的任务,我喜欢用linux,而会议网站托管在windows系统上,虽然装了双系统,但我还是比较懒,不喜欢经常切换系统.还好,linux可以实现登录windows服务器. ...
- QT之深入理解QThread
QT之深入理解QThread 理解QThread之前需要了解下QThread类,QThread拥有的资源如下(摘录于QT 5.1 帮助文档): 在以上资源中,本文重点关注槽:s ...
- Windows Azure入门教学系列 (二):部署第一个Web Role程序
本文是Windows Azure入门教学的第二篇文章. 在第一篇教学中,我们已经创建了第一个Web Role程序.在这篇教学中,我们将学习如何把该Web Role程序部署到云端. 注意:您需要购买Wi ...
- 根据li标签 查找class="alcw4 alcw41"对应的值
jrhmpt01:/root/lwp/0526# cat a2.pl use LWP::UserAgent; use DBI; use POSIX; use Data::Dumper; use HTM ...
- 性能测试之LoardRunner 检查点
概述 1.检查点概念 2.实例 以下是详细介绍 检查点:首先来看一下VuGen确定脚本运行成功的判断条件.在录制编写脚本后,通常就会进行回放,如果回放通过没有错误,就认为脚本是正确的.究竟VuGen怎 ...
- 关于Opengl中将24位BMP图片加入一个alpha通道并实现透明的问题
#include <windows.h>#include <GL/glut.h>#include <GL/glaux.h>#include <stdio.h& ...
- Servlet的学习(三)
本篇接上一篇<Servlet的学习(二)> ,主要讲诉如何使用MyEclipse来开发Servlet,和导入Servlet所需要的源代码. 现在我们来创建一个web应用,就叫[myserv ...
- Solaris 11的自动化安装(AI server)的搭建
solaris 11 总体比solaris 10很多变动的地方,可以去官方网站上面学习:http://www.oracle.com/technetwork/server-storage/solaris ...
- 3-04. 一元多项式的乘法与加法运算(20)(ZJU_PAT 结构体)
题目链接:http://pat.zju.edu.cn/contests/ds/3-04 设计函数分别求两个一元多项式的乘积与和. 输入格式说明: 输入分2行.每行分别先给出多项式非零项的个数.再以指数 ...
- leetcode Sum Root to Leaf Numbers(所有路径之和)
转载请注明来自souldak,微博:@evagle 观察题目给的返回值类型是int,可以断定这棵树的高度不会超过10,所以数据量其实是非常小的.那就直接dfs遍历这棵树,然后到叶子节点的时候将值加到最 ...