免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1029 | 回复: 0
打印 上一主题 下一主题

全自动 TSPITR--基于RMAN-LOGSEQ [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2015-09-21 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-19 13:56 |只看该作者 |倒序浏览
1、创建测试表空间user02。这里我就不写创建语句了。
2、创建测试表
  SQL>create table test (id number(5),name varchar2(5)) tablespace user02;
  SQL>insert into test values(1,'jason');
  SQL>commit;
3、sqlplus / as sysdba
   SQL>alter system switch logfile;
4、rman target/
  RMAN> backup database format '/oracle/databak/20110111/%U' plus archivelog format  '/oracle/databak/20110111/%U' delete input;
  RMAN>backup current controlfile format='/oracle/databak/20110111/%d.ctl' REUSE;
5、sqlplus / as sysdba
  SQL>select * from test;
     ID NAME
  --------- -----
     1 jason
 SQL> archive log list;
 Database log mode              Archive Mode
 Automatic archival             Enabled
 Archive destination            USE_DB_RECOVERY_FILE_DEST
 Oldest online log sequence     58
 Next log sequence to archive   60
 Current log sequence           60

 SQL>drop table test;
 SQL>alter system switch logfile;
6、rman target/
 
RMAN> recover tablespace user02 until logseq 60 auxiliary destination '/oracle/auxi/';

Starting recover at 05-JAN-11
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=159 devtype=DISK
RMAN-05026: WARNING: presuming following set of tablespaces applies to specified point in time

List of tablespaces expected to have UNDO segments
tablespace SYSTEM
tablespace UNDOTBS1

Creating automatic instance, with SID='olqD'

initialization parameters used for automatic instance:
db_name=ORCL
compatible=10.2.0.1.0
db_block_size=8192
db_files=200
db_unique_name=tspitr_ORCL_olqD
large_pool_size=1M
shared_pool_size=110M
#No auxiliary parameter file used
db_create_file_dest=/oracle/auxi/
control_files=/oracle/auxi//cntrl_tspitr_ORCL_olqD.f


starting up automatic instance ORCL

Oracle instance started

Total System Global Area     205520896 bytes

Fixed Size                     1218508 bytes
Variable Size                146802740 bytes
Database Buffers              50331648 bytes
Redo Buffers                   7168000 bytes
Automatic instance created

contents of Memory Script:
{
# set the until clause
set until  logseq 60 thread 1;
# restore the controlfile
restore clone controlfile;
# mount the controlfile
sql clone 'alter database mount clone database';
# archive current online log for tspitr to a resent until time
sql 'alter system archive log current';
# avoid unnecessary autobackups for structural changes during TSPITR
sql 'begin dbms_backup_restore.AutoBackupFlag(FALSE); end;';
}
executing Memory Script

executing command: SET until clause

Starting restore at 05-JAN-11
allocated channel: ORA_AUX_DISK_1
channel ORA_AUX_DISK_1: sid=37 devtype=DISK

channel ORA_AUX_DISK_1: starting datafile backupset restore
channel ORA_AUX_DISK_1: restoring control file
channel ORA_AUX_DISK_1: reading from backup piece /oracle/databak/20110111/16m1b65f_1_1
channel ORA_AUX_DISK_1: restored backup piece 1
piece handle=/oracle/databak/20110111/16m1b65f_1_1 tag=TAG20110105T075902
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:02
output filename=/oracle/auxi/cntrl_tspitr_ORCL_olqD.f
Finished restore at 05-JAN-11

sql statement: alter database mount clone database

sql statement: alter system archive log current

sql statement: begin dbms_backup_restore.AutoBackupFlag(FALSE); end;
released channel: ORA_DISK_1
released channel: ORA_AUX_DISK_1

contents of Memory Script:
{
# generated tablespace point-in-time recovery script
# set the until clause
set until  logseq 60 thread 1;
plsql <<<-- tspitr_2
declare
  sqlstatement       varchar2(512);
  offline_not_needed exception;
  pragma exception_init(offline_not_needed, -01539);
begin
  sqlstatement := 'alter tablespace '||  'USER02' ||' offline for recover';
  krmicd.writeMsg(6162, sqlstatement);
  krmicd.execSql(sqlstatement);
exception
  when offline_not_needed then
    null;
end; >>>;
# set an omf destination filename for restore
set newname for clone datafile  1 to new;
# set an omf destination filename for restore
set newname for clone datafile  2 to new;
# set an omf destination tempfile
set newname for clone tempfile  1 to new;
# set a destination filename for restore
set newname for datafile  9 to
 "/oracle/product/10.2.0/oradata/orcl/user02.dbf";
# rename all tempfiles
switch clone tempfile all;
# restore the tablespaces in the recovery set plus the auxilliary tablespaces
restore clone datafile  1, 2, 9;
switch clone datafile all;
#online the datafiles restored or flipped
sql clone "alter database datafile  1 online";
#online the datafiles restored or flipped
sql clone "alter database datafile  2 online";
#online the datafiles restored or flipped
sql clone "alter database datafile  9 online";
# make the controlfile point at the restored datafiles, then recover them
recover clone database tablespace  "USER02", "SYSTEM", "UNDOTBS1" delete archivelog;
alter clone database open resetlogs;
# PLUG HERE the creation of a temporary tablespace if export fails due to lack
# of temporary space.
# For example in Unix these two lines would do that:
#sql clone "create tablespace aux_tspitr_tmp
#           datafile ''/tmp/aux_tspitr_tmp.dbf'' size 500K";
}
executing Memory Script

executing command: SET until clause

sql statement: alter tablespace USER02 offline for recover

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

executing command: SET NEWNAME

renamed temporary file 1 to /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_temp_%u_.tmp in control file

Starting restore at 05-JAN-11
allocated channel: ORA_AUX_DISK_1
channel ORA_AUX_DISK_1: sid=39 devtype=DISK

channel ORA_AUX_DISK_1: starting datafile backupset restore
channel ORA_AUX_DISK_1: specifying datafile(s) to restore from backup set
restoring datafile 00001 to /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_system_%u_.dbf
restoring datafile 00002 to /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_undotbs1_%u_.dbf
restoring datafile 00009 to /oracle/product/10.2.0/oradata/orcl/user02.dbf
channel ORA_AUX_DISK_1: reading from backup piece /oracle/databak/20110111/15m1b626_1_1
channel ORA_AUX_DISK_1: restored backup piece 1
piece handle=/oracle/databak/20110111/15m1b626_1_1 tag=TAG20110105T075902
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:37
Finished restore at 05-JAN-11

datafile 1 switched to datafile copy
input datafile copy recid=16 stamp=739613074 filename=/oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_system_6l7fch1l_.dbf
datafile 2 switched to datafile copy
input datafile copy recid=17 stamp=739613074 filename=/oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_undotbs1_6l7fch56_.dbf

sql statement: alter database datafile  1 online

sql statement: alter database datafile  2 online

sql statement: alter database datafile  9 online

Starting recover at 05-JAN-11
using channel ORA_AUX_DISK_1

starting media recovery

channel ORA_AUX_DISK_1: starting archive log restore to default destination
channel ORA_AUX_DISK_1: restoring archive log
archive log thread=1 sequence=59
channel ORA_AUX_DISK_1: reading from backup piece /oracle/databak/20110111/17m1b65i_1_1
channel ORA_AUX_DISK_1: restored backup piece 1
piece handle=/oracle/databak/20110111/17m1b65i_1_1 tag=TAG20110105T080050
channel ORA_AUX_DISK_1: restore complete, elapsed time: 00:00:03
archive log filename=/oracle/product/10.2.0/db_1/dbs/arch1_59_738400851.dbf thread=1 sequence=59
channel clone_default: deleting archive log(s)
archive log filename=/oracle/product/10.2.0/db_1/dbs/arch1_59_738400851.dbf recid=58 stamp=739613077
media recovery complete, elapsed time: 00:00:01
Finished recover at 05-JAN-11

database opened

contents of Memory Script:
{
# export the tablespaces in the recovery set
host 'exp userid =\"/@\(DESCRIPTION=\(ADDRESS=\(PROTOCOL=beq\)\(PROGRAM=/oracle/product/10.2.0/db_1/bin/oracle\)\(ARGV0=oracleolqD\)\(ARGS=^'\(DESCRIPTION=\(LOCAL=YES\)\(ADDRESS=\(PROTOCOL=beq\)\)\)^'\)\(ENVS=^'ORACLE_SID=olqD^'\)\)\(CONNECT_DATA=\(SID=olqD\)\)\) as sysdba\" point_in_time_recover=y tablespaces=
 USER02 file=
tspitr_a.dmp';
# shutdown clone before import
shutdown clone immediate
# import the tablespaces in the recovery set
host 'imp userid =\"/@ as sysdba\" point_in_time_recover=y file=
tspitr_a.dmp';
# online/offline the tablespace imported
sql "alter tablespace  USER02 online";
sql "alter tablespace  USER02 offline";
# enable autobackups in case user does open resetlogs from RMAN after TSPITR
sql 'begin dbms_backup_restore.AutoBackupFlag(TRUE); end;';
}
executing Memory Script


Export: Release 10.2.0.1.0 - Production on Wed Jan 5 08:04:48 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.


Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
Export done in US7ASCII character set and AL16UTF16 NCHAR character set
server uses ZHS16GBK character set (possible charset conversion)
Note: table data (rows) will not be exported

About to export Tablespace Point-in-time Recovery objects...
For tablespace USER02 ...
. exporting cluster definitions
. exporting table definitions
. . exporting table                           TEST
. . exporting table                          SALES
EXP-00091: Exporting questionable statistics.
. exporting referential integrity constraints
. exporting triggers
. end point-in-time recovery
Export terminated successfully with warnings.
host command complete

database closed
database dismounted
Oracle instance shut down


Import: Release 10.2.0.1.0 - Production on Wed Jan 5 08:05:00 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.


Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options

Export file created by EXPORT:V10.02.01 via conventional path
About to import Tablespace Point-in-time Recovery objects...
import done in US7ASCII character set and AL16UTF16 NCHAR character set
import server uses ZHS16GBK character set (possible charset conversion)
. importing SYS's objects into SYS
. . importing table                         "TEST"
. importing SCOTT's objects into SCOTT
. . importing table                        "SALES"
. importing SYS's objects into SYS
Import terminated successfully without warnings.
host command complete

sql statement: alter tablespace  USER02 online

sql statement: alter tablespace  USER02 offline

sql statement: begin dbms_backup_restore.AutoBackupFlag(TRUE); end;

Removing automatic instance
Automatic instance removed
auxiliary instance file /oracle/auxi/cntrl_tspitr_ORCL_olqD.f deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_system_6l7fch1l_.dbf deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_undotbs1_6l7fch56_.dbf deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/datafile/o1_mf_temp_6l7fdvko_.tmp deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/onlinelog/o1_mf_1_6l7fdr4r_.log deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/onlinelog/o1_mf_2_6l7fdrys_.log deleted
auxiliary instance file /oracle/auxi/TSPITR_ORCL_OLQD/onlinelog/o1_mf_3_6l7fdt05_.log deleted
Finished recover at 05-JAN-11

7、将表空间置于online
RMAN> sql 'alter tablespace user02 online';
测试:
SQL>selerct * from test;
  ID NAME
  --------- -----
  1 jason
备份表空间user02。
RMAN> backup tablespace user02 format='/oracle/databak/20110111/%d_%s.dbf';
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP