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;
相关推荐
在IT领域中,Oracle数据库因其高性能、可靠性及可扩展性被广泛应用于企业级应用之中。对于Oracle数据库管理员而言,掌握如何高效地进行数据库备份与恢复是一项至关重要的技能。本文将根据给定的信息“如何备份还原...
对于Oracle数据库,NBU提供了精确到表空间、数据文件甚至单个表的恢复选项。在恢复前,需确保目标环境的Oracle实例配置与备份时一致,或者通过RMAN(Recovery Manager)进行数据库恢复时调整相关参数。NBU的恢复向导...
在Oracle数据库环境中,有时需要将一个RAC(Real Application Clusters)集群数据库恢复到一个异地的单实例数据库。这个过程涉及到多个步骤,包括备份文件的传输、初始化参数文件的调整以及恢复操作。以下是一个详细的...
Oracle数据库是企业级广泛应用的关系型数据库系统,其稳定性和可靠性是其核心优势。在实际运行中,为了确保数据的安全,定期备份和恢复策略是至关重要的。本资料"oracle数据库自动备份与恢复.zip"包含了在Linux和...
《基于Oracle数据库的国土资源空间数据异地容灾保护》这篇文章探讨了如何使用Oracle数据库技术来管理和保护重要的国土资源空间数据。文章作者张书波指出,由于这些数据的采集成本高、应用频繁、变化快速以及数据量...
"手把手教你ORACLE RMAN异地备份" 该教程旨在教你如何使用ORACLE RMAN实现异地备份,解决了由于数据量急剧增加、...该教程提供了一个详细的ORACLE RMAN异地备份解决方案,解决了服务器空间不足和备份恢复的困难问题。
【Oracle 数据库异地备份与恢复】是针对Oracle数据库在分布式环境下的保护策略,它涉及到C/S(客户端/服务器)架构的应用。在这个系统中,管理员能够通过局域网或广域网对远程Oracle数据库进行备份和恢复操作,确保...
### 循序渐进Oracle数据库管理、优化与备份恢复 #### Oracle数据库管理 Oracle数据库是全球最流行的数据库管理系统之一,广泛应用于企业级数据处理。管理Oracle数据库涉及多个方面,包括但不限于: 1. **安装与...
【PB环境下Oracle数据库的备份与恢复】主要涉及的是在使用PB(PowerBuilder)软件的环境中,如何对Oracle数据库进行有效的备份和恢复操作。Oracle数据库作为一款广泛使用的大型关系型数据库管理系统,其数据的安全性...
不完全介质恢复则针对那些仅需恢复到特定事务一致性的场景,适用于数据丢失不严重的情况。 在制定恢复策略时,DBA需要综合考虑多个因素,以实现最优的恢复效果。首先是业务目标,不同的业务对数据的实时性和准确性...
Oracle 19c 备份恢复-导入导出是指使用 Oracle 数据库提供的工具 exp 和 imp 实现数据库的备份恢复和数据的导入导出。本文将详细介绍 Oracle 19c 备份恢复-导入导出的基本命令、工作方式、模式、选项和高级选项。 ...
2.6 ORACLE数据库的备份与恢复 39 2.6.1 Export 转入程序 40 2.6.2 Import 转入程序 42 2.6.3 增量卸出/装入 44 第3章 ORACLE数据库的网络应用 46 3.1 SQL*Net产品介绍 46 3.2 配置客户机/服务器结构 47 3.2.1 配置...
### Oracle数据库的备份与恢复 #### 一、Oracle数据库备份方式概述 Oracle数据库备份与恢复是维护数据库稳定性的重要环节。本文将详细介绍Oracle数据库备份的方法及其恢复过程,特别关注Oracle数据库导入导出的...
【Oracle数据库备份与故障恢复】 Oracle数据库在众多企业和组织中被广泛使用,其稳定性和可靠性至关重要。然而,由于各种原因,如硬件故障、软件错误或人为失误,数据库可能会遭受破坏,这时就需要有效的备份和恢复...
Oracle数据库是企业级的关系型数据库管理系统,确保其数据的安全性和可恢复性至关重要。自动备份是实现这一目标的重要手段,而使用BAT脚本可以方便地将这一过程自动化。 在描述中提到了一个博文链接,虽然具体内容...
- 安装相同版本的Oracle数据库软件,并创建必要的目录结构。 - 设置目标实例的参数文件`init<dbname>.ora`,例如: ```bash *.db_name='xzdb' *.enable_pluggable_database=true ``` - 这些步骤确保了目标...
Oracle数据库因其稳定性和可靠性而被广泛应用于企业级应用中,为了保障数据的安全性与可用性,定期进行数据库备份至关重要。本文将详细介绍一种通过`exp`命令配合`crontab`定时任务实现Oracle数据库自动备份的方法。...
【Oracle数据库在AIX下备份与恢复的改进】 在当今信息化社会中,Oracle数据库作为一款广泛应用的关系型数据库,其在AIX(Advanced Interactive eXecutive)操作系统下的备份与恢复策略至关重要。AIX是由IBM开发的...
### 海量数据环境下Oracle数据库系统架构设计与优化的关键知识点 #### 一、大数据时代的背景与挑战 在当前的大数据时代背景下,随着社会信息化进程的不断深入和社会经济活动的日益数字化,企业面临的最大挑战之一...