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

Oracle数据库表空间级的异地不完全恢复

Oracle资料库做异地恢复时,全库的完全恢复需要很大的空间和很长的时间。如果采用基于模式的恢复方式仅仅恢复某一模式下所有物

Oracle 资料库做异地恢复时,全库的完全恢复需要很大的空间和很长的时间。 如果采用基于模式的恢复方式仅仅恢复某一模式下所有物

Oracle 资料库做异地恢复时,全库的完全恢复需要很大的空间和很长的时间。
如果采用基于模式的恢复方式仅仅恢复某一模式下所有物件,而不用去恢复所有的资料,这将节省大量的时间和空间。
这个在 Oracle 9i 版本中经常使用,在 10g 、 11g 中也可以使用一下。
下面案例是在 10g 的环境下将一个 ASM 上的 RAC 资料库的资料恢复到一个档案系统上单实例资料库中,并且是只恢复几个使用者下的资料。
操作步骤如下:
1 、将备份组拷贝到要恢复的机器上,如果空间够的话,可以将资料备份、控制档案备份和归档备份一起拷贝过来,如果不够的话,先拷贝控制档案备份和资料档案备份。
2 、关闭资料库,启动到 nomount 状态进行控制档的恢复
shutdown immediate;
startup nomount;
rman target /
restore controlfile from '/data/urpdb/urpdb_ctl_ikn3tot4_1_1.20120222';
3 、修改控制档
查询要恢复的使用者的表空间资讯
select owner,tablespace_name,count(*) from dba_segments group by owner,tablespace_name;
查找这些表空间和系统表空间( 'SYSTEM','SYSAUX', 'UNDOTBS1','UNDOTBS2', 'UNDOTBS3', 'UNDOTBS4' )对应的资料档案
select *
from dba_data_files
where tablespace_name in
('TSP_URP', 'TSP_URP_INDEX', 'TSP_JC', 'TSP_JC_INDEX', 'TSP_GXSJ',
'TSP_GXSJ_INDE', 'TSP_OWB', 'TSP_YJSSJCK', 'USERS', 'SYSTEM',
'SYSAUX', 'UNDOTBS1','UNDOTBS2', 'UNDOTBS3', 'UNDOTBS4');
SQL> alter database backup controlfile to trace;
修改控制档并执行:
CREATE CONTROLFILE REUSE DATABASE "URPDB" RESETLOGS FORCE LOGGING ARCHIVELOG
MAXLOGFILES 192
MAXLOGMEMBERS 3
MAXDATAFILES 1024
MAXINSTANCES 32
MAXLOGHISTORY 9088
LOGFILE
GROUP 1 (
'/opt/app/oracle/oradata/URPDB/group1_2.log',
'/opt/app/oracle/oradata/URPDB/group1_1.log'
) SIZE 10M,
GROUP 2 (
'/opt/app/oracle/oradata/URPDB/group2_2.log',
'/opt/app/oracle/oradata/URPDB/group2_1.log'
) SIZE 10M,
GROUP 3 (
'/opt/app/oracle/oradata/URPDB/group3_2.log',
'/opt/app/oracle/oradata/URPDB/group3_1.log'
) SIZE 10M,
GROUP 11 '/opt/app/oracle/oradata/URPDB/group11_1.log' SIZE 100M,
GROUP 12 '/opt/app/oracle/oradata/URPDB/group12_1.log' SIZE 100M,
GROUP 13 '/opt/app/oracle/oradata/URPDB/group13_1.log' SIZE 100M,
GROUP 14 '/opt/app/oracle/oradata/URPDB/group14_1.log' SIZE 100M,
GROUP 15 '/opt/app/oracle/oradata/URPDB/group15_1.log' SIZE 100M
-- STANDBY LOGFILE
DATAFILE
'/opt/app/oracle/oradata/URPDB/system01.dbf',
'/opt/app/oracle/oradata/URPDB/undotbs1.dbf',
'/opt/app/oracle/oradata/URPDB/sysaux.dbf',
'/opt/app/oracle/oradata/URPDB/users.dbf',
'/opt/app/oracle/oradata/URPDB/undotbs2.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_urp.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_urp_index.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_gxsj.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_urp.dbf_1.ora',
'/opt/app/oracle/oradata/URPDB/tsp_owb.ora',
'/opt/app/oracle/oradata/URPDB/tsp_jc.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_jc_index.dbf',
'/opt/app/oracle/oradata/URPDB/tsp_yjssjck.dbf',
'/opt/app/oracle/oradata/URPDB/undotbs03.dbf',
'/opt/app/oracle/oradata/URPDB/undotbs04.dbf'
CHARACTER SET AL32UTF8
;
mount 资料库;
SQL> alter database mount;


select name from v$datafile;
--select 'alter database rename file '''||name||''' to '''|| replace(name,'+URPDBDG','/opt/app/oracle/oradata/URPDB')||''';' from v$datafile;
3 、将备份资料档案拷贝到测试机
rman>catalog start with '/data/urpdb/'; 执行一下,就是将这个目录下的资料档案的备份档案写入了 catalog 。
4 、 restore 资料库
select file#,name from v$datafile ; --- 看看控制档中资料档案存放的位置,,这里是 “ +URPDBDG/..." ,替换为目标资料库档存放的位置。
set linesize 300
column name format a200
set pagesize 100


select 'set newname for datafile '||file#||' to '''||replace(name,'+URPDBDG','/opt/app/oracle/oradata/urpdb')||''';' newname from v$datafile -- 如果一个目标目录不够,可以用多个目标目录
union all
select 'restore datafile '||file#||';' newname from v$datafile;


select *
from dba_data_files
where tablespace_name in
('TSP_URP', 'TSP_URP_INDEX', 'TSP_JC', 'TSP_JC_INDEX', 'TSP_GXSJ',
'TSP_GXSJ_INDE', 'TSP_OWB', 'TSP_YJSSJCK', 'USERS', 'SYSTEM',
'SYSAUX', 'UNDOTBS1','UNDOTBS2', 'UNDOTBS3', 'UNDOTBS4');


rman>
run
{
allocate channel ch01 type disk;
allocate channel ch02 type disk;
set until time "to_date('2012-02-23 10:00:00','yyyy-mm-dd hh24:mi:ss')";
set newname for datafile 1 to '/opt/app/oracle/oradata/URPDB/system01.dbf';
set newname for datafile 2 to '/opt/app/oracle/oradata/URPDB/undotbs1.dbf';
set newname for datafile 3 to '/opt/app/oracle/oradata/URPDB/sysaux.dbf';
set newname for datafile 4 to '/opt/app/oracle/oradata/URPDB/users.dbf';
set newname for datafile 6 to '/opt/app/oracle/oradata/URPDB/undotbs2.dbf';
set newname for datafile 9 to '/opt/app/oracle/oradata/URPDB/tsp_urp.dbf';
set newname for datafile 10 to '/opt/app/oracle/oradata/URPDB/tsp_urp_index.dbf';
set newname for datafile 14 to '/opt/app/oracle/oradata/URPDB/tsp_gxsj.dbf';
set newname for datafile 16 to '/opt/app/oracle/oradata/URPDB/tsp_urp.dbf_1.ora';
set newname for datafile 18 to '/opt/app/oracle/oradata/URPDB/tsp_owb.ora';
set newname for datafile 19 to '/opt/app/oracle/oradata/URPDB/tsp_jc.dbf';
set newname for datafile 20 to '/opt/app/oracle/oradata/URPDB/tsp_jc_index.dbf';
set newname for datafile 26 to '/opt/app/oracle/oradata/URPDB/tsp_yjssjck.dbf';
set newname for datafile 29 to '/opt/app/oracle/oradata/URPDB/undotbs03.dbf';
set newname for datafile 30 to '/opt/app/oracle/oradata/URPDB/undotbs04.dbf';
restore datafile 1;
restore datafile 2;
restore datafile 3;
restore datafile 4;
restore datafile 6;
restore datafile 9;
restore datafile 10;
restore datafile 14;
restore datafile 16;
restore datafile 18;
restore datafile 19;
restore datafile 20;
restore datafile 26;
restore datafile 29;
restore datafile 30;
switch datafile all;
release channel ch01;
release channel ch02;
}
5 、修改日志档和暂存档案的路径为目标资料库的路径(可与 restore 同时进行)
select member from v$logfile;


select name from v$tempfile;


select 'alter database rename file '''||member||''' to '''|| replace(member,'+URPDBDG','/opt/app/oracle/oradata/URPDB')||''';' from v$logfile;


alter database rename file '+YWKDG/ywk/onlinelog/group15_1.log' to '/opt/app/oracle/oradata2/YWKDG/group15_1.log';
。。。。。


select 'alter database rename file '''||name||''' to '''|| replace(name,'+URPDBDG','/opt/app/oracle/oradata2/urpdb/')||''';' from v$tempfile;


alter database rename file '+YWKDG/ywk/tempfile/tsp_zc_temp02.dbf' to '/opt/app/oracle/oradata2/YWKDG/tsp_zc_temp02.dbf';


6 、将归档档拷到目标资料库伺服器,
rman>catalog start with '/data/urpdb/'; 执行一下,就是将这个目录下的归档档的备份档案写入了 catalog 。
run
{
allocate channel ch01 type disk;
allocate channel ch02 type disk;
set until time "to_date('2012-02-23 10:00:00','yyyy-mm-dd hh24:mi:ss')";
recover database;
release channel ch01;
release channel ch02;
}
或则
SQL> select to_char(checkpoint_time,'yyyy-mm-dd hh24:mi:ss') from v$datafile;


S QL> select file#,checkpoint_change# from v$datafile order by checkpoint_change#;


FILE# CHECKPOINT_CHANGE#
---------- ------------------
14 2793109724
20 2793109725
6 2793232002
19 2793232002
18 2793258889
26 2793258889
9 2793281171
30 2793281171
1 2793283158
16 2793301522
29 2793301522
2 2793304369
10 2793304369
4 2793333238
3 2793333238


15 rows selected.


run
{
allocate channel ch01 type disk;
allocate channel ch02 type disk;
set until scn 2793333238;
recover database ;
release channel ch01;
release channel ch02;
}


如果 recover 资料库缺少档,可以到主库去查是哪个档,然后拷贝过来再 recover 一次。
RMAN> list backupset of archivelog logseq 7438 thread 4;


RMAN> crosscheck backupset;
delete expired backupset;


7 、 alter database open resetlogs;

更多Oracle相关信息见Oracle 专题页面 ?tid=12


推荐阅读
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Win10上安装WinPythonHadoop的详细步骤,包括安装Python环境、安装JDK8、安装pyspark、安装Hadoop和Spark、设置环境变量、下载winutils.exe等。同时提醒注意Hadoop版本与pyspark版本的一致性,并建议重启电脑以确保安装成功。 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 仙贝旅行是日本最大的旅游服务平台之一,为广大用户提供优质的日本定制游服务。随着用户数量的增长,仙贝旅行决定与智齿科技合作,全面替换原有客服系统,打造全新的在线客服体系。该体系具备多渠道快速接入的能力,让仙贝旅行轻松与各个渠道的接入用户完成沟通。同时,机器人与人工协同发力,提升客户服务水平。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了StartingzookeeperFAILEDTOSTART相关的知识,希望对你有一定的参考价值。下载路径:https://ar ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • SAP羞辱国产软件商:技术停在10年前
    SAP中国研究院总裁芮祥麟表示,国产软件厂商过于热衷概念炒作,技术水平停留在10年前的客户端架构水平。他认为,国内厂商推出基于SOA的产品或转型SAAS模式是不可能的,研发新架构需要时间。当前最热门的概念是云计算,芮祥麟呼吁国产厂商应该潜心研发底层架构。 ... [详细]
  • IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多 ... [详细]
author-avatar
潘泓浩_236
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有