AI智能
改变未来

【TTS】传输表空间Linux ->AIX 基于rman

【TTS】传输表空间Linux asm -> AIX asm 基于rman

一.1  BLOG文档结构图

 

 

 

一.2  前言部分

 

一.2.1  导读和注意事项

各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~:

① 异构平台下传输表空间的实施

② 传输表空间基于表空间的read only和rman2种方式

③ 平台字节序、自包含概念

④ expdp/impdp的应用

 

  Tips:

       ① 若文章代码格式有错乱,推荐使用搜狗或360浏览器,也可以下载pdf格式的文档来查看,pdf文档下载地址:http://yunpan.cn/cdEQedhCs2kFz (提取码:ed9b) 

       ② 本篇BLOG中命令的输出部分需要特别关注的地方我都用灰色背景和粉红色字体来表示,比如下边的例子中,thread 1的最大归档日志号为33,thread 2的最大归档日志号为43是需要特别关注的地方;而命令一般使用黄色背景和红色字体标注;对代码或代码输出部分的注释一般采用蓝色字体表示。

 

  List of Archived Logs in backup set 11

  Thrd Seq     Low SCN    Low Time            Next SCN   Next Time

  —- ——- ———- ——————- ———- ———

  1    32      1621589    2015-05-29 11:09:52 1625242    2015-05-29 11:15:48

  1    33      1625242    2015-05-29 11:15:48 1625293    2015-05-29 11:15:58

  2    42      1613951    2015-05-29 10:41:18 1625245    2015-05-29 11:15:49

  2    43      1625245    2015-05-29 11:15:49 1625253    2015-05-29 11:15:53

 

 

 

 

[ZFXDESKDB1:root]:/>lsvg -o

T_XDESK_APP1_vg

rootvg

[ZFXDESKDB1:root]:/>

00:27:22 SQL> alter tablespace idxtbs read write;

 

 

====》2097152*512/1024/1024/1024=1G 

 

 

 

 

 

 

 

本文如有错误或不完善的地方请大家多多指正,ITPUB留言或QQ皆可,您的批评指正是我写作的最大动力。

 

 

一.2.2  相关参考文章链接

其他异构平台迁移的一些文章参考:

【推荐】 oracle 异构平台迁移之传输表空间一例 http://blog.itpub.net/26736162/viewspace-1391913/

【推荐】 oracle 传输表空间一例 http://blog.itpub.net/26736162/viewspace-1375260/

【推荐】 利用rman来实现linux平台数据库复制到windows平台数据库 http://blog.itpub.net/26736162/viewspace-1352436/

【推荐】 直接复制数据文件实现linux平台数据库复制到windows平台数据库 http://blog.itpub.net/26736162/viewspace-1352243/

【TTS】传输表空间Linux asm -> AIX asm  http://blog.itpub.net/26736162/viewspace-1987949/

 

 

一.3  相关知识点扫盲

可传输表空间的特性主要用于进行库对库的表空间复制,要进行传输的表空间必须置于read-only模式。如果生产库不允许表空间置为只读模式,没关系,方法还是有的,通过RMAN备份也可以创建可传输表空间集。要使用可传输表空间的特性,oracle至少是8i企业版或更高版本。如果是相同操作系统平台相互导入,则8i及以上版本均可支持,但如果是不同操作系统平台,数据库版本至少10g。被传输的表空间即可以是字典管理,也可以是本地管理。并且自oracle9i开始,被传输表空间的block size可以与目标数据库的block size不同。

 

可传输表空间(还有个集)最大的优势是其速度比export/import或unload/load要快的多。因为可传输表空间主要是复制数据文件到目标路径,然后再使用export/import或Data Pump export/import等应用仅导出/导入表空间对象的元数据到新数据库。

关于可传输表空间,还有个集(Transportable Tablespace Sets)的创建,其中都提到了很重要一点,就是被传输的表空间在传输过程中必须置为 read-only。而在实际操作过程中,对于某些生产数据库,将表空间置为 read-only 是件非常复杂的事情甚至完全不允许,有了 RMAN 的 Transportable Tablespace,这一切都得以避免。RMAN 通过备份创建可传输表空间集,它并不需要存取活动的数据文件,相应也就不需要将表空间置为 read-only。因此,数据库可用性得到提升,尤其对于超大的表空间,因为被传输的表空间在此期间仍可进行读写操作,而且把表空间置为 read-only 模式可能会花费较长时间,

使用 RMAN 创建可传输表空间集,允许你在传输过程中指定目标恢复时间点或 SCN,这样传输的数据可以更灵活,不必完全复制现有表空间,只要备份中存在,你就可以选择性的恢复数据。例如,你的备份策略为保留一周,你希望创建的可传输表空间中数据是截止本月底最后一天的数据,那么你在下个月第一周内任何时候都可以进行传输操作而不需要考虑这期间生产库是否会有写入操作。

 

 

一.3.1  注意事项

 

 

 

☞  注意:

 

① source和target database的数据库版本最好一致,否则会因为db time zone 不一致导致报如下错误,但是如果source大于等于target的话是可以的,向下兼容的

ORA-39002: invalid operation

ORA-39322: Cannot use transportabletablespace with timestamp with timezone columns and different timezone version.

 

② source和target端的字符集必须一致,例如如下情况报错:

source为 ZHS16GBK,target为AL32UTF8

ORA-39123: Data Pump transportable tablespace job aborted

ORA-29345: cannot plug a tablespace into a database using an incompatible character set

 

Tartget db char set AL32UTF8 is not a superset of ZHS16GBK.

Failed to plug in a tablespace due to incompatible

  database character set\”AL32UTF8\” and

  transportable set database character set \”ZHS16GBK\”

 

  ③ source和target database的compatible 参数最好一致,但source如果小于等于target端的话是可以的,例如source为11.2.0.4.0,target为11.2.0.0.0就不行,impdp的时候报错:

ORA-39123: Data Pump transportable tablespace job aborted

ORA-00721: changes by release 11.2.0.4.0 cannot be used by release 11.2.0.0.0

 

 

 

 

一.4  实验部分

 

一.4.1  实验环境介绍

项目

source db

target db

db 类型

单实例

单实例

db version

11.2.0.3

11.2.0.4

db 存储

ASM

ASM

ORACLE_SID

orclasm

ora2lhr

db_name

orclasm

ora2lhr

主机IP地址:

192.168.59.30

22.188.194.66

OS版本及kernel版本

RHEL6.5 64位,2.6.32-504.16.2.el6.x86_64

AIX 64位 7.1.0.0

OS hostname

rhel6_lhr

ZFXDESKDB2

platform_name

Linux x86 64-bit

AIX-Based Systems (64-bit)

db time zone

14

14

compatible

11.2.0.0.0

11.2.0.4.0

字符集

ZHS16GBK

ZHS16GBK

归档模式

Archive Mode

Archive Mode

 

一.4.2  实验目标

 

要实现将自定义的应用程序表空间app1tbs,app2tbs,idxtbs从源平台传递到目标平台,而在实际的工作过程中,需要将AIX上的数据库迁移到Linux,或者将Linux上的数据库迁移到AIX上,除了exp/imp和expdp/impdp外,最常用的就是传输表空间了,若是整个库迁移的话,我们需要做的就是把业务用户和业务表空间的数据迁移过来就行,Undo、temp、system等等的就不用迁移了,整个处理过程和本文档的处理过程大同小异,需要关注的是业务对象的个数、大小、状态等。

 

一.4.3  实验过程

 

 

————————————————————————————————————-

 

 

 

 

 

 

 

一.5  source端环境准备

 

 

一.5.1  在源库上创建3个用户应用的表空间

 

[oracle@rhel6_lhr ~]$ sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.3.0 Production on 星期日 1月 31 23:34:27 2016

 

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

 

 

连接到:

Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 – 64bit Production

With the Partitioning, Automatic Storage Management, OLAP, Data Mining

and Real Application Testing options

 

23:34:27 SQL>  create tablespace app1tbs datafile \’+DATA\’ size 10m;

 

表空间已创建。

 

已用时间:  00: 00: 07.60

23:34:42 SQL> create tablespace app2tbs datafile \’+DATA\’ size 10m;

 

表空间已创建。

 

已用时间:  00: 00: 27.25

23:35:53 SQL> create tablespace idxtbs datafile \’+DATA\’ size 10m;

 

表空间已创建。

 

已用时间:  00: 00: 09.45

23:36:09 SQL> set line 9999 pagesize 9999

23:36:12 SQL> SELECT   a.NAME,  b.NAME FROM v$tablespace a , v$datafile b WHERE a.TS#=b.TS#  ;

 

NAME                           NAME

———————–       ——————————————————————————-

SYSTEM                         +DATA/orclasm/datafile/system.256.850260145

SYSAUX                         +DATA/orclasm/datafile/sysaux.257.850260145

UNDOTBS1                       +DATA/orclasm/datafile/undotbs1.258.851526539

USERS                          +DATA/orclasm/datafile/users.259.850260147

EXAMPLE                        +DATA/orclasm/datafile/example.265.850260295

APP1TBS                        +DATA/orclasm/datafile/app1tbs.268.902619275

APP2TBS     8000                   +DATA/orclasm/datafile/app2tbs.280.902619327

TS_LHR                         +DATA/orclasm/datafile/ts_lhr.269.852632495

ENCRYPTED_TS                   +DATA/orclasm/datafile/encrypted_ts.272.854650889

GOLDENGATE                     +DATA/orclasm/datafile/goldengate.273.862829891

IDXTBS                         +DATA/orclasm/datafile/idxtbs.281.902619361

TS_LHR                         +DATA/orclasm/datafile/ts_lhr.284.869738273

USERS                          +FRA/orclasm/datafile/users.449.880121199

SYSTEM                         +FRA/orclasm/datafile/system.349.880121287

 

已选择14行。

 

已用时间:  00: 00: 00.80

23:36:21 SQL>

 

 

一.5.2  在相应的表空间创建表和索引

23:36:21 SQL> create user user_app1 identified by user_app1 default tablespace app1tbs;

 

用户已创建。

 

已用时间:  00: 00: 00.14

23:40:13 SQL> create user user_app2 identified by user_app2 default tablespace app1tbs;

 

用户已创建。

 

已用时间:  00: 00: 00.35

23:43:51 SQL> create user user_app2 identified by user_app2 default tablespace app2tbs;

 

用户已创建。

 

已用时间:  00: 00: 02.72

23:43:56 SQL>  grant connect,resource to user_app1;

 

授权成功。

 

已用时间:  00: 00: 00.06

23:44:50 SQL> grant connect,resource to user_app2;

 

授权成功。

 

已用时间:  00: 00: 00.00

23:44:52 SQL> create table user_app1.app1_tab tablespace app1tbs as select * from scott.emp;

 

表已创建。

 

已用时间:  00: 00: 01.02

23:45:09 SQL>  create table user_app2.app2_tab tablespace app2tbs as select * from scott.dept;

 

表已创建。

 

已用时间:  00: 00: 00.23

23:45:27 SQL> create index user_app1.idx_emp_ename on user_app1.app1_tab(ename) tablespace idxtbs;

 

索引已创建。

 

已用时间:  00: 00: 00.25

23:45:51 SQL> create index user_app2.idx_dept_dname on user_app2.app2_tab(dname) tablespace idxtbs;

 

索引已创建。

 

已用时间:  00: 00: 00.01

23:46:13 SQL>

 

一.6  判断平台支持并确定字节序

如果传输表空间集到不同的平台,则要确定对于源和目标平台这种跨平台表空间被支持,也要确定每个平台的字节序,如果平台具有相同的字节序,则不需要进行转化,否则必须做一个表空间集转化,在源端或目标端。

一.6.1  在源平台查询

23:46:13 SQL> col platform_name for a40

23:48:55 SQL> select d.platform_name,tp.endian_format from v$transportable_platform tp,v$database d where tp.platform_name=d.platform_name;

 

PLATFORM_NAME                            ENDIAN_FORMAT

—————————————- ————–

Linux x86 64-bit                         Little

 

已用时间:  00: 00: 00.19

23:49:13 SQL>

 

结论:当前的系统平台支持跨平台表空间传输(因为上面的查询有记录返回)

 

一.6.2  在目标平台查询

 

[ZFXDESKDB2:oracle]:/oracle>ORACLE_SID=ora2lhr

[ZFXDESKDB2:oracle]:/oracle>sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.4.0 Production on Mon Feb 1 13:47:14 2016

 

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

 

 

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

 

SYS@ora2lhr> col platform_name for a40

SYS@ora2lhr> select d.platform_name,tp.endian_format from v$transportable_platform tp,v$database d where tp.platform_name=d.platform_name;

 

PLATFORM_NAME                            ENDIAN_FORMAT

—————————————- —————————-

AIX-Based Systems (64-bit)               Big

 

 

结论: 当前的AIX平台支持跨平台的表空间传输

源平台和目标平台的Endian_format 不同,source端为Little,target端为Big,所以需要进行表空间集转换,前边说过在源端或目标端都可以进行转换,这里我们选择在目标端来进行转换。

 

一.7  选择自包含的表空间集

一.7.1  进行检查

Indicates whether a full or partial dependency check is required. If TRUE, treats all IN and OUT pointers(dependencies) and captures them as violations if they are not self-contained in the transportable set.

先试试要传输app1tbs和idxtbs这2个表空间:

SQL> execute dbms_tts.transport_set_check(\’app1tbs,idxtbs\’,true);

 

PL/SQL procedure successfully completed.

 

 

一.7.2  查看检查结果

SQL> col violations for a70

 

23:50:53 SQL> select * from transport_set_violations;

 

VIOLATIONS

——————————————————————————————————————————————-

ORA-39907: 索引 USER_APP2.IDX_DEPT_DNAME (在表空间 IDXTBS 中) 指向表 USER_APP2.APP2_TAB (在表空间 APP2TBS 中)。

 

已用时间:  00: 00: 00.18

23:51:14 SQL>

 

结论: 在idxtbs表空间中IDX_DEPT_DNAME索引指向了表空间集外的SYS.APP2_TAB表,所以这里选择app1tabs,app2tabs,idxtbs作为新的表空间集再次进行检查

 

23:51:14 SQL> execute dbms_tts.transport_set_check(\’app1tbs,app2tbs,idxtbs\’,true);

 

PL/SQL 过程已成功完成。

 

已用时间:  00: 00: 07.24

23:52:14 SQL> select * from transport_set_violations;

 

未选定行

 

已用时间:  00: 00: 00.00

23:52:54 SQL>

结论: 此时这个表空间集已经不在违背自包含的条件,可以确定为一个可传输表空间集

 

一.8  产生可传输表空间集

一.8.1  rman全备份

对源数据库执行备份,在执行备份时一定要加上include current controlfile否则执行transport tablespace命令时会出现以下错误信息:

Automatic instance removed

RMAN-00571: ===========================================================

RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============

RMAN-00571: ===========================================================

RMAN-03002: failure of tranport tablespace command at 03/26/2015 20:24:22

RMAN-03015: error occurred in stored script Memory Script

RMAN-06026: some targets not found – aborting restore

RMAN-06024: no backup or copy of the control file found to restore

 

 

[oracle@rhel6_lhr orclasm]$ rman target /

 

恢复管理器: Release 11.2.0.3.0 – Production on 星期一 2月 1 22:05:43 2016

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

已连接到目标数据库: ORCLASM (DBID=3424884828)

RMAN> list backup;

 

说明与资料档案库中的任何备份都不匹配

 

RMAN> backup as backupset database  format  \’/u05/oracle/oracle_bk/orclasm/full_%n_%T_%t_%s_%p.bak\’ include current controlfile plus archivelog delete input;

 

 

启动 backup 于 2016-02-01 22:11:24

当前日志已存档

使用通道 ORA_DISK_1

使用通道 ORA_DISK_2

通道 ORA_DISK_1: 正在启动归档日志备份集

通道 ORA_DISK_1: 正在指定备份集内的归档日志

输入归档日志线程=1 序列=2400 RECID=2409 STAMP=898694914

输入归档日志线程=1 序列=2401 RECID=2410 STAMP=898702456

输入归档日志线程=1 序列=2402 RECID=2411 STAMP=898703657

输入归档日志线程=1 序列=2403 RECID=2412 STAMP=898703964

输入归档日志线程=1 序列=2404 RECID=2413 STAMP=898705171

输入归档日志线程=1 序列=2405 RECID=2414 STAMP=898705314

输入归档日志线程=1 序列=2406 RECID=2415 STAMP=898707838

通道 ORA_DISK_1: 正在启动段 1 于 2016-02-01 22:12:08

通道 ORA_DISK_2: 正在启动归档日志备份集

通道 ORA_DISK_2: 正在指定备份集内的归档日志

输入归档日志线程=1 序列=2407 RECID=2416 STAMP=898708044

输入归档日志线程=1 序列=2408 RECID=2417 STAMP=902613950

输入归档日志线程=1 序列=2409 RECID=2418 STAMP=902614593

输入归档日志线程=1 序列=2410 RECID=2419 STAMP=902618226

输入归档日志线程=1 序列=2411 RECID=2420 STAMP=902699234

输入归档日志线程=1 序列=2412 RECID=2421 STAMP=902700168

输入归档日志线程=1 序列=2413 RECID=2422 STAMP=902700702

通道 ORA_DISK_2: 正在启动段 1 于 2016-02-01 22:12:38

通道 ORA_DISK_1: 已完成段 1 于 2016-02-01 22:12:47

段句柄=/home/oracle/oracle_bk/orclasm/q9qss7lj_1_1_ORCLASM.bak 标记=TAG20160201T221152 注释=NONE

通道 ORA_DISK_1: 备份集已完成, 经过时间:00:00:39

通道 ORA_DISK_2: 已完成段 1 于 2016-02-01 22:13:17

段句柄=/home/oracle/oracle_bk/orclasm/qaqss7lp_1_1_ORCLASM.bak 标记=TAG20160201T221152 注释=NONE

通道 ORA_DISK_2: 备份集已完成, 经过时间:00:00:39

完成 backup 于 2016-02-01 22:13:17

 

启动 backup 于 2016-02-01 22:13:22

使用通道 ORA_DISK_1

使用通道 ORA_DISK_2

通道 ORA_DISK_1: 正在启动全部数据文件备份集

通道 ORA_DISK_1: 正在指定备份集内的数据文件

输入数据文件: 文件号=00033 名称=+FRA/orclasm/datafile/users.449.880121199

输入数据文件: 文件号=00002 名称=+DATA/orclasm/datafile/sysaux.257.850260145

输入数据文件: 文件号=00001 名称=+DATA/orclasm/datafile/system.256.850260145

输入数据文件: 文件号=00005 名称=+DATA/orclasm/datafile/example.265.850260295

输入数据文件: 文件号=00008 名称=+DATA/orclasm/datafile/ts_lhr.269.852632495

输入数据文件: 文件号=00014 名称=+DATA/orclasm/datafile/ts_lhr.284.869738273

输入数据文件: 文件号=00034 名称=+FRA/orclasm/datafile/system.349.880121287

通道 ORA_DISK_1: 正在启动段 1 于 2016-02-01 22:13:40

通道 ORA_DISK_2: 正在启动全部数据文件备份集

通道 ORA_DISK_2: 正在指定备份集内的数据文件

输入数据文件: 文件号=00004 名称=+DATA/orclasm/datafile/users.259.850260147

输入数据文件: 文件号=00003 名称=+DATA/orclasm/datafile/undotbs1.258.851526539

输入数据文件: 文件号=00010 名称=+DATA/orclasm/datafile/goldengate.273.862829891

输入数据文件: 文件号=00006 名称=+DATA/orclasm/datafile/app1tbs.268.902619275

输入数据文件: 文件号=00007 名称=+DATA/orclasm/datafile/app2tbs.280.902619327

输入数据文件: 文件号=00011 名称=+DATA/orclasm/datafile/idxtbs.281.902619361

输入数据文件: 文件号=00009 名称=+DATA/orclasm/datafile/encrypted_ts.272.854650889

通道 ORA_DISK_2: 正在启动段 1 于 2016-02-01 22:13:47

通道 ORA_DISK_1: 已完成段 1 于 2016-02-01 22:21:15

段句柄=/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700816_1867_1.bak 标记=TAG20160201T221331 注释=NONE

通道 ORA_DISK_1: 备份集已完成, 经过时间:00:07:35

通道 ORA_DISK_1: 正在启动全部数据文件备份集

通道 ORA_DISK_1: 正在指定备份集内的数据文件

备份集内包括当前控制文件

通道 ORA_DISK_1: 正在启动段 1 于 2016-02-01 22:21:52

通道 ORA_DISK_1: 已完成段 1 于 2016-02-01 22:22:17

段句柄=/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902701286_1869_1.bak 标记=TAG20160201T221331 注释=NONE

通道 ORA_DISK_1: 备份集已完成, 经过时间:00:00:25

通道 ORA_DISK_2: 已完成段 1 于 2016-02-01 22:26:07

段句柄=/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700821_1868_1.bak 标记=TAG20160201T221331 注释=NONE

通道 ORA_DISK_2: 备份集已完成, 经过时间:00:12:20

完成 backup 于 2016-02-01 22:26:07

 

启动 backup 于 2016-02-01 22:26:11

当前日志已存档

使用通道 ORA_DISK_1

使用通道 ORA_DISK_2

通道 ORA_DISK_1: 正在启动归档日志备份集

通道 ORA_DISK_1: 正在指定备份集内的归档日志

输入归档日志线程=1 序列=2414 RECID=2423 STAMP=902701474

通道 ORA_DISK_1: 正在启动段 1 于 2016-02-01 22:26:41

通道 ORA_DISK_2: 正在启动归档日志备份集

通道 ORA_DISK_2: 正在指定备份集内的归档日志

输入归档日志线程=1 序列=2415 RECID=2424 STAMP=902701578

通道 ORA_DISK_2: 正在启动段 1 于 2016-02-01 22:26:46

通道 ORA_DISK_1: 已完成段 1 于 2016-02-01 22:26:53

段句柄=/home/oracle/oracle_bk/orclasm/qeqss8h1_1_1_ORCLASM.bak 标记=TAG20160201T222636 注释=NONE

通道 ORA_DISK_1: 备份集已完成, 经过时间:00:00:12

通道 ORA_DISK_2: 已完成段 1 于 2016-02-01 22:27:01

段句柄=/home/oracle/oracle_bk/orclasm/qfqss8h5_1_1_ORCLASM.bak 标记=TAG20160201T222636 注释=NONE

通道 ORA_DISK_2: 备份集已完成, 经过时间:00:00:15

完成 backup 于 2016-02-01 22:27:01

 

启动 Control File and SPFILE Autobackup 于 2016-02-01 22:27:08

段 handle=/home/oracle/oracle_bk/orclasm/ctlfile_autoback_ORCLASM_c-3424884828-20160201-0a.bak comment=NONE

完成 Control File and SPFILE Autobackup 于 2016-02-01 22:27:33

 

RMAN> list backupset;

 

 

备份集列表

===================

 

 

BS 关键字  大小       设备类型占用时间 完成时间          

——- ———- ———– ———— ——————-

1743    276.69M    DISK        00:00:35     2016-02-01 22:12:38

        BP 关键字: 1814   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T221152

段名:/home/oracle/oracle_bk/orclasm/q9qss7lj_1_1_ORCLASM.bak

 

  备份集 1743 中的已存档日志列表

  线程序列     低 SCN    时间下限            下一个 SCN   下一次

  —- ——- ———- ——————- ———- ———

  1    2400    55314243   2015-12-17 11:42:30 55356997   2015-12-17 13:28:31

  1    2401    55356997   2015-12-17 13:28:31 55380655   2015-12-17 15:34:02

  1    2402    55380655   2015-12-17 15:34:02 55391244   2015-12-17 15:54:10

  1    2403    55391244   2015-12-17 15:54:10 55401844   2015-12-17 15:59:14

  1    2404    55401844   2015-12-17 15:59:14 55411350   2015-12-17 16:19:24

  1    2405    55411350   2015-12-17 16:19:24 55423877   2015-12-17 16:21:47

  1    2406    55423877   2015-12-17 16:21:47 55455247   2015-12-17 17:03:49

 

BS 关键字  大小       设备类型占用时间 完成时间          

——- ———- ———– ———— ——————-

1744    214.24M    DISK        00:01:01     2016-02-01 22:13:10

        BP 关键字: 1815   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T221152

段名:/home/oracle/oracle_bk/orclasm/qaqss7lp_1_1_ORCLASM.bak

 

  备份集 1744 中的已存档日志列表

  线程序列     低 SCN    时间下限            下一个 SCN   下一次

  —- ——- ———- ——————- ———- ———

  1    2407    55455247   2015-12-17 17:03:49 55466900   2015-12-17 17:07:18

  1    2408    55466900   2015-12-17 17:07:18 55509831   2016-01-31 22:05:41

  1    2409    55509831   2016-01-31 22:05:41 55521588   2016-01-31 22:16:26

  1    2410    55521588   2016-01-31 22:16:26 55554213   2016-01-31 23:17:01

  1    2411    55554213   2016-01-31 23:17:01 55596287   2016-02-01 21:47:10

  1    2412    55596287   2016-02-01 21:47:10 55599466   2016-02-01 22:02:41

  1    2413    55599466   2016-02-01 22:02:41 55620029   2016-02-01 22:11:25

 

BS 关键字  类型 LV 大小       设备类型 经过时间 完成时间          

——- —- — ———- ———– ———— ——————-

1745    Full    2.34G      DISK        00:07:33     2016-02-01 22:21:09

        BP 关键字: 1816   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T221331

段名:/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700816_1867_1.bak

  备份集 1745 中的数据文件列表

  文件 LV 类型 Ckp SCN    Ckp 时间            名称

  —- — —- ———- ——————- —-

  1       Full 55620642   2016-02-01 22:13:41 +DATA/orclasm/datafile/system.256.850260145

  2       Full 55620642   2016-02-01 22:13:41 +DATA/orclasm/datafile/sysaux.257.850260145

  5       Full 55620642   2016-02-01 22:13:41 +DATA/orclasm/datafile/example.265.850260295

  8       Full 55620642   2016-02-01 22:13:41 +DATA/orclasm/datafile/ts_lhr.269.852632495

  14      Full 55620642   2016-02-01 22:13:41 +DATA/orclasm/datafile/ts_lhr.284.869738273

  33      Full 55620642   2016-02-01 22:13:41 +FRA/orclasm/datafile/users.449.880121199

  34      Full 55620642   2016-02-01 22:13:41 +FRA/orclasm/datafile/system.349.880121287

 

BS 关键字  类型 LV 大小       设备类型 经过时间 完成时间          

——- —- — ———- ———– ———— ——————-

1746    Full    12.77M     DISK        00:00:44     2016-02-01 22:22:10

        BP 关键字: 1817   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T221331

段名:/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902701286_1869_1.bak

  包括的控制文件: Ckp SCN: 55622293     Ckp 时间: 2016-02-01 22:21:30

 

BS 关键字  类型 LV 大小       设备类型 经过时间 完成时间          

——- —- — ———- ———– ———— ——————-

1747    Full    2.54G      DISK        00:12:22     2016-02-01 22:26:03

        BP 关键字: 1818   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T221331

段名:/u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700821_1868_1.bak

  备份集 1747 中的数据文件列表

  文件 LV 类型 Ckp SCN    Ckp 时间            名称

  —- — —- ———- ——————- —-

  3       Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/undotbs1.258.851526539

  4       Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/users.259.850260147

  6       Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/app1tbs.268.902619275

  7       Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/app2tbs.280.902619327

  9       Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/encrypted_ts.272.854650889

  10      Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/goldengate.273.862829891

  11      Full 55620651   2016-02-01 22:13:47 +DATA/orclasm/datafile/idxtbs.281.902619361

 

BS 关键字  大小       设备类型占用时间 完成时间          

——- ———- ———– ———— ——————-

1748    39.85M     DISK        00:00:10     2016-02-01 22:26:51

        BP 关键字: 1819   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T222636

段名:/home/oracle/oracle_bk/orclasm/qeqss8h1_1_1_ORCLASM.bak

 

  备份集 1748 中的已存档日志列表

  线程序列     低 SCN    时间下限            下一个 SCN   下一次

  —- ——- ———- ——————- ———- ———

  1    2414    55620029   2016-02-01 22:11:25 55623076   2016-02-01 22:24:03

 

BS 关键字  大小       设备类型占用时间 完成时间          

——- ———- ———– ———— ——————-

1749    16.97M     DISK        00:00:07     2016-02-01 22:26:52

        BP 关键字: 1820   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T222636

段名:/home/oracle/oracle_bk/orclasm/qfqss8h5_1_1_ORCLASM.bak

 

  备份集 1749 中的已存档日志列表

  线程序列     低 SCN    时间下限            下一个 SCN   下一次

  —- ——- ———- ——————- ———- ———

  1    2415    55623076   2016-02-01 22:24:03 55623713   2016-02-01 22:26:13

 

BS 关键字  类型 LV 大小       设备类型 经过时间 完成时间          

——- —- — ———- ———– ———— ——————-

1750    Full    12.80M     DISK        00:00:20     2016-02-01 22:27:28

        BP 关键字: 1821   状态: AVAILABLE  已压缩: NO  标记: TAG20160201T222708

段名:/home/oracle/oracle_bk/orclasm/ctlfile_autoback_ORCLASM_c-3424884828-20160201-0a.bak

  包含的 SPFILE: 修改时间: 2015-11-11 19:53:11

  SPFILE db_unique_name: ORCLASM

  包括的控制文件: Ckp SCN: 55624410     Ckp 时间: 2016-02-01 22:27:08

 

一.8.2  生成结果集

这个转换步骤需要特别注意的是/u05/tmp的空间大小,因为需要建立一个辅助实例,所以空间大小至少应该是source库表空间大小的总和加上需要传输的表空间的数据文件的大小,否则会因为空间不足而导致转换失败。

RMAN> transport tablespace app1tbs,app2tbs,idxtbs tablespace destination \’/u05/tmp\’ auxiliary destination \’/u05/tmp\’;

 

使用目标数据库控制文件替代恢复目录

RMAN-05026: 警告: 假定以下表空间集适用于指定的时间点

 

表空间列表要求具有 UNDO 段

表空间 SYSTEM

表空间 UNDOTBS1

 

使用 SID=\’ypkw\’ 创建自动实例

 

供自动实例使用的初始化参数:

db_name=ORCLASM

db_unique_name=ypkw_tspitr_ORCLASM

compatible=11.2.0.0.0

db_block_size=8192

db_files=200

sga_target=280M

processes=50

db_create_file_dest=/u05/tmp

log_archive_dest_1=\’location=/u05/tmp\’

#No auxiliary parameter file used

 

 

启动自动实例 ORCLASM

 

Oracle 实例已启动

 

系统全局区域总计     292278272 字节

 

Fixed Size                     2227744 字节

Variable Size                100663776 字节

Database Buffers             184549376 字节

Redo Buffers                   4837376 字节

自动实例已创建

对恢复集表空间运行 TRANSPORT_SET_CHECK

TRANSPORT_SET_CHECK 已成功完成

 

内存脚本的内容:

{

# set requested point in time

set until  scn 55627689;

# restore the controlfile

restore clone controlfile;

# mount the controlfile

sql clone \’alter database mount clone database\’;

# archive current online log

sql \’alter system archive log current\’;

}

正在执行内存脚本

 

正在执行命令: SET until clause

 

启动 restore 于 2016-02-01 22:44:21

分配的通道: ORA_AUX_DISK_1

通道 ORA_AUX_DISK_1: SID=59 设备类型=DISK

分配的通道: ORA_AUX_DISK_2

通道 ORA_AUX_DISK_2: SID=10 设备类型=DISK

 

通道 ORA_AUX_DISK_1: 正在开始还原数据文件备份集

通道 ORA_AUX_DISK_1: 正在还原控制文件

通道 ORA_AUX_DISK_1: 正在读取备份片段 /home/oracle/oracle_bk/orclasm/ctlfile_autoback_ORCLASM_c-3424884828-20160201-0a.bak

通道 ORA_AUX_DISK_1: 段句柄 = /home/oracle/oracle_bk/orclasm/ctlfile_autoback_ORCLASM_c-3424884828-20160201-0a.bak 标记 = TAG20160201T222708

通道 ORA_AUX_DISK_1: 已还原备份片段 1

通道 ORA_AUX_DISK_1: 还原完成, 用时: 00:00:01

输出文件名=/u05/tmp/ORCLASM/controlfile/o1_mf_cbyvtc77_.ctl

完成 restore 于 2016-02-01 22:44:28

 

sql 语句: alter database mount clone database

 

sql 语句: alter system archive log current

 

内存脚本的内容:

{

# set requested point in time

set until  scn 55627689;

# set destinations for recovery set and auxiliary set datafiles

set newname for clone datafile  1 to new;

set newname for clone datafile  34 to new;

set newname for clone datafile  3 to new;

set newname for clone datafile  2 to new;

set newname for clone tempfile  1 to new;

set newname for datafile  6 to

\”/u05/tmp/o1_mf_app1tbs_%u_.dbf\”;

set newname for datafile  7 to

\”/u05/tmp/o1_mf_app2tbs_%u_.dbf\”;

set newname for datafile  11 to

\”/u05/tmp/o1_mf_idxtbs_%u_.dbf\”;

# switch all tempfiles

switch clone tempfile all;

# restore the tablespaces in the recovery set and the auxiliary set

restore clone datafile  1, 34, 3, 2, 6, 7, 11;

switch clone datafile all;

}

正在执行内存脚本

 

正在执行命令: SET until clause

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

正在执行命令: SET NEWNAME

 

临时文件 1 在控制文件中已重命名为 /u05/tmp/ORCLASM/datafile/o1_mf_temp_%u_.tmp

 

启动 restore 于 2016-02-01 22:44:42

使用通道 ORA_AUX_DISK_1

使用通道 ORA_AUX_DISK_2

 

通道 ORA_AUX_DISK_1: 正在开始还原数据文件备份集

通道 ORA_AUX_DISK_1: 正在指定从备份集还原的数据文件

通道 ORA_AUX_DISK_1: 将数据文件 00001 还原到 /u05/tmp/ORCLASM/datafile/o1_mf_system_%u_.dbf

通道 ORA_AUX_DISK_1: 将数据文件 00034 还原到 /u05/tmp/ORCLASM/datafile/o1_mf_system_%u_.dbf

通道 ORA_AUX_DISK_1: 将数据文件 00002 还原到 /u05/tmp/ORCLASM/datafile/o1_mf_sysaux_%u_.dbf

通道 ORA_AUX_DISK_1: 正在读取备份片段 /u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700816_1867_1.bak

通道 ORA_AUX_DISK_2: 正在开始还原数据文件备份集

通道 ORA_AUX_DISK_2: 正在指定从备份集还原的数据文件

通道 ORA_AUX_DISK_2: 将数据文件 00003 还原到 /u05/tmp/ORCLASM/datafile/o1_mf_undotbs1_%u_.dbf

通道 ORA_AUX_DISK_2: 将数据文件 00006 还原到 /u05/tmp/o1_mf_app1tbs_%u_.dbf

通道 ORA_AUX_DISK_2: 将数据文件 00007 还原到 /u05/tmp/o1_mf_app2tbs_%u_.dbf

通道 ORA_AUX_DISK_2: 将数据文件 00011 还原到 /u05/tmp/o1_mf_idxtbs_%u_.dbf

通道 ORA_AUX_DISK_2: 正在读取备份片段 /u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700821_1868_1.bak

通道 ORA_AUX_DISK_2: 段句柄 = /u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700821_1868_1.bak 标记 = TAG20160201T221331

通道 ORA_AUX_DISK_2: 已还原备份片段 1

通道 ORA_AUX_DISK_2: 还原完成, 用时: 00:00:25

通道 ORA_AUX_DISK_1: 段句柄 = /u05/oracle/oracle_bk/orclasm/full_ORCLASMx_20160201_902700816_1867_1.bak 标记 = TAG20160201T221331

通道 ORA_AUX_DISK_1: 已还原备份片段 1

通道 ORA_AUX_DISK_1: 还原完成, 用时: 00:01:35

完成 restore 于 2016-02-01 22:46:21

 

数据文件 1 已转换成数据文件副本

输入数据文件副本 RECID=58 STAMP=902702782 文件名=/u05/tmp/ORCLASM/datafile/o1_mf_system_cbyvtz00_.dbf

数据文件 34 已转换成数据文件副本

输入数据文件副本 RECID=59 STAMP=902702782 文件名=/u05/tmp/ORCLASM/datafile/o1_mf_system_cbyvtz5j_.dbf

数据文件 3 已转换成数据文件副本

输入数据文件副本 RECID=60 STAMP=902702782 文件名=/u05/tmp/ORCLASM/datafile/o1_mf_undotbs1_cbyvtyz4_.dbf

数据文件 2 已转换成数据文件副本

输入数据文件副本 RECID=61 STAMP=902702782 文件名=/u05/tmp/ORCLASM/datafile/o1_mf_sysaux_cbyvtyxm_.dbf

数据文件 6 已转换成数据文件副本

输入数据文件副本 RECID=62 STAMP=902702782 文件名=/u05/tmp/o1_mf_app1tbs_cbyvtz0l_.dbf

数据文件 7 已转换成数据文件副本

输入数据文件副本 RECID=63 STAMP=902702782 文件名=/u05/tmp/o1_mf_app2tbs_cbyvtz1y_.dbf

数据文件 11 已转换成数据文件副本

输入数据文件副本 RECID=64 STAMP=902702782 文件名=/u05/tmp/o1_mf_idxtbs_cbyvtz52_.dbf

 

内存脚本的内容:

{

# set requested point in time

set until  scn 55627689;

# online the datafiles restored or switched

sql clone \”alter database datafile  1 online\”;

sql clone \”alter database datafile  34 online\”;

sql clone \”alter database datafile  3 online\”;

sql clone \”alter database datafile  2 online\”;

sql clone \”alter database datafile  6 online\”;

sql clone \”alter database datafile  7 online\”;

sql clone \”alter database datafile  11 online\”;

# recover and open resetlogs

recover clone database tablespace  \”APP1TBS\”, \”APP2TBS\”, \”IDXTBS\”, \”SYSTEM\”, \”UNDOTBS1\”, \”SYSAUX\” delete archivelog;

alter clone database open resetlogs;

}

正在执行内存脚本

 

正在执行命令: SET until clause

 

sql 语句: alter database datafile  1 online

 

sql 语句: alter database datafile  34 online

 

sql 语句: alter database datafile  3 online

 

sql 语句: alter database datafile  2 online

 

sql 语句: alter database datafile  6 online

 

sql 语句: alter database datafile  7 online

 

sql 语句: alter database datafile  11 online

 

启动 recover 于 2016-02-01 22:46:23

使用通道 ORA_AUX_DISK_1

使用通道 ORA_AUX_DISK_2

 

正在开始介质的恢复

 

线程 1 序列 2414 的归档日志已作为文件 +FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2414.283.902701451 存在于磁盘上

线程 1 序列 2415 的归档日志已作为文件 +FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2415.467.902701575 存在于磁盘上

线程 1 序列 2416 的归档日志已作为文件 +FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2416.332.902701653 存在于磁盘上

线程 1 序列 2417 的归档日志已作为文件 +FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2417.308.902701787 存在于磁盘上

线程 1 序列 2418 的归档日志已作为文件 +FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2418.366.902701939 存在于磁盘上

归档日志文件名=+FR8000A/orclasm/archivelog/2016_02_01/thread_1_seq_2414.283.902701451 线程=1 序列=2414

归档日志文件名=+FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2415.467.902701575 线程=1 序列=2415

归档日志文件名=+FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2416.332.902701653 线程=1 序列=2416

归档日志文件名=+FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2417.308.902701787 线程=1 序列=2417

归档日志文件名=+FRA/orclasm/archivelog/2016_02_01/thread_1_seq_2418.366.902701939 线程=1 序列=2418

介质恢复完成, 用时: 00:00:14

完成 recover 于 2016-02-01 22:46:41

 

数据库已打开

 

内存脚本的内容:

{

# make read only the tablespace that will be exported

sql clone \’alter tablespace  APP1TBS read only\’;

sql clone \’alter tablespace  APP2TBS read only\’;

sql clone \’alter tablespace  IDXTBS read only\’;

# create directory for datapump export

sql clone \”create or replace directory STREAMS_DIROBJ_DPDIR as \’\’

/u05/tmp\’\’\”;

}

正在执行内存脚本

 

sql 语句: alter tablespace  APP1TBS read only

 

sql 语句: alter tablespace  APP2TBS read only

 

sql 语句: alter tablespace  IDXTBS read only

 

sql 语句: create or replace directory STREAMS_DIROBJ_DPDIR as \’\’/u05/tmp\’\’

 

正在执行元数据导出…

   EXPDP> 启动 \”SYS\”.\”TSPITR_EXP_ypkw\”: 

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/PLUGTS_BLK

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/TABLE

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/INDEX/INDEX

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/INDEX_STATISTICS

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/TABLE_STATISTICS

   EXPDP> 处理对象类型 TRANSPORTABLE_EXPORT/POST_INSTANCE/PLUGTS_BLK

   EXPDP> 已成功加载/卸载了主表 \”SYS\”.\”TSPITR_EXP_ypkw\”

   EXPDP> ******************************************************************************

   EXPDP> SYS.TSPITR_EXP_ypkw 的转储文件集为:

   EXPDP>   /u05/tmp/dmpfile.dmp

   EXPDP> ******************************************************************************

   EXPDP> 可传输表空间 APP1TBS 所需的数据文件:

   EXPDP>   /u05/tmp/o1_mf_app1tbs_cbyvtz0l_.dbf

   EXPDP> 可传输表空间 APP2TBS 所需的数据文件:

   EXPDP>   /u05/tmp/o1_mf_app2tbs_cbyvtz1y_.dbf

   EXPDP> 可传输表空间 IDXTBS 所需的数据文件:

   EXPDP>   /u05/tmp/o1_mf_idxtbs_cbyvtz52_.dbf

   EXPDP> 作业 \”SYS\”.\”TSPITR_EXP_ypkw\” 已于 22:48:00 成功完成

导出完毕

 

/*

   The following command may be used to import the tablespaces.

   Substitute values for <logon> and <directory>.

   impdp <logon> directory=<directory> dumpfile= \’dmpfile.dmp\’ transport_datafiles= /u05/tmp/o1_mf_app1tbs_cbyvtz0l_.dbf, /u05/tmp/o1_mf_app2tbs_cbyvtz1y_.dbf, /u05/tmp/o1_mf_idxtbs_cbyvtz52_.dbf

*/

————————————————————–

— Start of sample PL/SQL script for importing the tablespaces

————————————————————–

— creating directory objects

CREATE DIRECTORY STREAMS$DIROBJ$1 AS  \’/u05/tmp/\’;

CREATE DIRECTORY STREAMS$DIROBJ$DPDIR AS  \’/u05/tmp\’;

/* PL/SQL Script to import the exported tablespaces */

DECLARE

  — the datafiles

  tbs_files     dbms_streams_tablespace_adm.file_set;

  cvt_files     dbms_streams_tablespace_adm.file_set;

  — the dumpfile to import

  dump_file     dbms_streams_tablespace_adm.file;

  dp_job_name   VARCHAR2(30) := NULL;

  — names of tablespaces that were imported

  ts_names       dbms_streams_tablespace_adm.tablespace_set;

BEGIN

  — dump file name and location

  dump_file.file_name :=  \’dmpfile.dmp\’;

  dump_file.directory_object := \’STREAMS$DIROBJ$DPDIR\’;

  — forming list of datafiles for import

  tbs_files( 1).file_name :=  \’o1_mf_app1tbs_cbyvtz0l_.dbf\’;

  tbs_files( 1).directory_object :=  \’STREAMS$DIROBJ$1\’;

  tbs_files( 2).file_name :=  \’o1_mf_app2tbs_cbyvtz1y_.dbf\’;

  tbs_files( 2).directory_object :=  \’STREAMS$DIROBJ$1\’;

  tbs_files( 3).file_name :=  \’o1_mf_idxtbs_cbyvtz52_.dbf\’;

  tbs_files( 3).directory_object :=  \’STREAMS$DIROBJ$1\’;

  — import tablespaces

  dbms_streams_tablespace_adm.attach_tablespaces(

    datapump_job_name      => dp_job_name,

    dump_file              => dump_file,

    tablespace_files       => tbs_files,

    converted_files        => cvt_files,

    tablespace_names       => ts_names);

  — output names of imported tablespaces

  IF ts_names IS NOT NULL AND ts_names.first IS NOT NULL THEN

    FOR i IN ts_names.first .. ts_names.last LOOP

      dbms_output.put_line(\’imported tablespace \’|| ts_names(i));

    END LOOP;

  END IF;

END;

/

— dropping directory objects

DROP DIRECTORY STREAMS$DIROBJ$1;

DROP DIRECTORY STREAMS$DIROBJ$DPDIR;

————————————————————–

— End of sample PL/SQL script

————————————————————–

 

删除自动实例

关闭自动实例

数据库已关闭

数据库已卸装

Oracle 实例已关闭

自动实例已删除

已删除辅助实例文件 /u05/tmp/ORCLASM/datafile/o1_mf_temp_cbyvytdt_.tmp

已删除辅助实例文件 /u05/tmp/ORCLASM/onlinelog/o1_mf_4_cbyvyqnp_.log

已删除辅助实例文件 /u05/tmp/ORCLASM/onlinelog/o1_mf_3_cbyvypkj_.log

已删除辅助实例文件 /u05/tmp/ORCLASM/onlinelog/o1_mf_2_cbyvyonl_.log

已删除辅助实例文件 /u05/tmp/ORCLASM/onlinelog/o1_mf_1_cbyvykf7_.log

已删除辅助实例文件 /u05/tmp/ORCLASM/datafile/o1_mf_sysaux_cbyvtyxm_.dbf

已删除辅助实例文件 /u05/tmp/ORCLASM/datafile/o1_mf_undotbs1_cbyvtyz4_.dbf

已删除辅助实例文件 /u05/tmp/ORCLASM/datafile/o1_mf_system_cbyvtz5j_.dbf

已删除辅助实例文件 /u05/tmp/ORCLASM/datafile/o1_mf_system_cbyvtz00_.dbf

已删除辅助实例文件 /u05/tmp/ORCLASM/controlfile/o1_mf_cbyvtc77_.ctl

 

RMAN>

 

[oracle@rhel6_lhr ~]$ cd /u05/tmp

[oracle@rhel6_lhr tmp]$ ll

total 30868

-rw-r—– 1 oracle asmadmin   118784 Feb  1 22:48 dmpfile.dmp

-rw-r–r– 1 oracle oinstall     2373 Feb  1 22:48 impscrpt.sql

-rw-r—– 1 oracle asmadmin 10493952 Feb  1 22:47 o1_mf_app1tbs_cbyvtz0l_.dbf

-rw-r—– 1 oracle asmadmin 10493952 Feb  1 22:47 o1_mf_app2tbs_cbyvtz1y_.dbf

-rw-r—– 1 oracle asmadmin 10493952 Feb  1 22:47 o1_mf_idxtbs_cbyvtz52_.dbf

drwxr-x— 5 oracle asmadmin     4096 Feb  1 22:44 ORCLASM

[oracle@rhel6_lhr tmp]$

 

 

一.9  传输数据文件和元数据到target端

这里需要传输转储元文件和数据文件到目标库

 

 

一.9.1  查看目标库数据文件位置和目录

[ZFXDESKDB2:oracle]:/oracle>ORACLE_SID=ora2lhr

[ZFXDESKDB2:oracle]:/oracle>sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.4.0 Production on Tue Feb 2 13:51:47 2016

 

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

 

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

 

SYS@ora2lhr> select name from v$datafile;

 

NAME

————————————————————————————————————————————

+DATA/ora2lhr/datafile/system.335.902674033

+DATA/ora2lhr/datafile/sysaux.336.902674033

+DATA/ora2lhr/datafile/undotbs1.337.902674033

+DATA/ora2lhr/datafile/users.338.902674033

+DATA/ora2lhr/datafile/example.348.902674109

 

SYS@ora2lhr> set line 9999

SYS@ora2lhr> col directory_name for a28

SYS@ora2lhr> col directory_path for a100

SYS@ora2lhr> select directory_name,directory_path from dba_directories;

 

DIRECTORY_NAME               DIRECTORY_PATH

—————————- —————————————————————————————————-

SUBDIR                       /oracle/app/oracle/product/11.2.0/db/demo/schema/order_entry//2002/Sep

SS_OE_XMLDIR                 /oracle/app/oracle/product/11.2.0/db/demo/schema/order_entry/

LOG_FILE_DIR                 /oracle/app/oracle/product/11.2.0/db/demo/schema/log/

MEDIA_DIR                    /oracle/app/oracle/product/11.2.0/db/demo/schema/product_media/

DATA_FILE_DIR                /oracle/app/oracle/product/11.2.0/db/demo/schema/sales_history/

XMLDIR                       /oracle/app/oracle/product/11.2.0/db/rdbms/xml

ORACLE_OCM_CONFIG_DIR        /oracle/app/oracle/product/11.2.0/db/ccr/state

DATA_PUMP_DIR                /oracle/app/oracle/admin/ora2lhr/dpdump/

ORACLE_OCM_CONFIG_DIR2       /oracle/app/oracle/product/11.2.0/db/ccr/state

 

9 rows selected.

 

SYS@ora2lhr>

SYS@ora2lhr>

 

一.9.2  拷贝文件到目标库相应位置并修改权限

 

 

 

 

 

 

[ZFXDESKDB2:root]:/>cd /oracle/app/oracle/admin/ora2lhr/dpdump

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>l

total 61728

-rw-r—–    1 root     system       118784 Feb 01 22:48 dmpfile.dmp

-rw-r—–    1 root     system         2373 Feb 01 22:48 impscrpt.sql

-rw-r—–    1 root     system     10493952 Feb 01 22:47 o1_mf_app1tbs_cbyvtz0l_.dbf

-rw-r—–    1 root     system     10493952 Feb 01 22:47 o1_mf_app2tbs_cbyvtz1y_.dbf

-rw-r—–    1 root     system     10493952 Feb 01 22:47 o1_mf_idxtbs_cbyvtz52_.dbf

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>chown oracle:dba ./*

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>l

total 61728

-rw-r—–    1 oracle   dba          118784 Feb 01 22:48 dmpfile.dmp

-rw-r—–    1 oracle   dba            2373 Feb 01 22:48 impscrpt.sql

-rw-r—–    1 oracle   dba        10493952 Feb 01 22:47 o1_mf_app1tbs_cbyvtz0l_.dbf

-rw-r—–    1 oracle   dba        10493952 Feb 01 22:47 o1_mf_app2tbs_cbyvtz1y_.dbf

-rw-r—–    1 oracle   dba        10493952 Feb 01 22:47 o1_mf_idxtbs_cbyvtz52_.dbf

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>

 

 

 

一.10  target端转换字节序

 

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>su – oracle

[ZFXDESKDB2:oracle]:/oracle>ORACLE_SID=ora2lhr

 

[ZFXDESKDB2:oracle]:/oracle>echo $ORACLE_SID

ora2lhr

[ZFXDESKDB2:oracle]:/oracle>rman target /

 

Recovery Manager: Release 11.2.0.4.0 – Production on Tue Feb 2 13:57:58 2016

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

connected to target database: ORA2LHR (DBID=4055514164)

 

RMAN> CONVERT DATAFILE

2> \”/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_app1tbs_cbyvtz0l_.dbf\”,

3> \”/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_app2tbs_cbyvtz1y_.dbf\”,

4> \”/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_idxtbs_cbyvtz52_.dbf\”

5> TO PLATFORM=\”AIX-Based Systems (64-bit)\”

6> FROM PLATFORM=\”Linux x86 64-bit\”

7> FORMAT \’+DATA\’;

 

Starting conversion at target at 2016-02-02 13:58:02

using target database control file instead of recovery catalog

allocated channel: ORA_DISK_1

channel ORA_DISK_1: SID=165 device type=DISK

channel ORA_DISK_1: starting datafile conversion

input file name=/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_app1tbs_cbyvtz0l_.dbf

converted datafile=+DATA/ora2lhr/datafile/app1tbs.265.902757483

channel ORA_DISK_1: datafile conversion complete, elapsed time: 00:00:01

channel ORA_DISK_1: starting datafile conversion

input file name=/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_app2tbs_cbyvtz1y_.dbf

converted datafile=+DATA/ora2lhr/datafile/app2tbs.264.902757485

channel ORA_DISK_1: datafile conversion complete, elapsed time: 00:00:01

channel ORA_DISK_1: starting datafile conversion

input file name=/oracle/app/oracle/admin/ora2lhr/dpdump/o1_mf_idxtbs_cbyvtz52_.dbf

converted datafile=+DATA/ora2lhr/datafile/idxtbs.262.902757485

channel ORA_DISK_1: datafile conversion complete, elapsed time: 00:00:01

Finished conversion at target at 2016-02-02 13:58:06

 

RMAN>

RMAN>

 

 

[ZFXDESKDB2:root]:/oracle/app/oracle/admin/ora2lhr/dpdump>

[ZFXDESKDB2:root]:/>su – grid

[ZFXDESKDB2:grid]:/home/grid>asmcmd

ASMCMD> cd +DATA/ora2lhr/datafile/

ASMCMD> ls

APP1TBS.265.902757483

APP2TBS.264.902757485

EXAMPLE.348.902674109

IDXTBS.262.902757485

SYSAUX.336.902674033

SYSTEM.335.902674033

UNDOTBS1.337.902674033

USERS.338.902674033

ASMCMD> ls -l

Type      Redund  Striped  Time             Sys  Name

DATAFILE  UNPROT  COARSE   FEB 02 13:00:00  Y    APP1TBS.265.902757483

DATAFILE  UNPROT  COARSE   FEB 02 13:00:00  Y    APP2TBS.264.902757485

DATAFILE  UNPROT  COARSE   FEB 02 09:00:00  Y    EXAMPLE.348.902674109

DATAFILE  UNPROT  COARSE   FEB 02 13:00:00  Y    IDXTBS.262.902757485

DATAFILE  UNPROT  COARSE   FEB 02 09:00:00  Y    SYSAUX.336.902674033

DATAFILE  UNPROT  COARSE   FEB 02 09:00:00  Y    SYSTEM.335.902674033

DATAFILE  UNPROT  COARSE   FEB 02 09:00:00  Y    UNDOTBS1.337.902674033

DATAFILE  UNPROT  COARSE   FEB 02 09:00:00  Y    USERS.338.902674033

ASMCMD>

 

 

一.11  target端开始导入数据

一.11.1  创建source库的2个用户并赋权限

如果不创建用户会报如下的错误:

ORA-39123: Data Pump transportable tablespace job aborted

ORA-29342: user USER_APP1 does not exist in the database

 

 

 

[ZFXDESKDB2:oracle]:/oracle>sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.4.0 Production on Tue Feb 2 14:08:33 2016

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

 

 

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

 

SYS@ora2lhr> create user user_app1 identified by user_app1;

 

User created.

 

SYS@ora2lhr> create user user_app2 identified by user_app2;

 

User created.

 

SYS@ora2lhr> grant connect , resource to user_app1;

 

Grant succeeded.

 

SYS@ora2lhr> grant connect , resource to user_app2;

 

Grant succeeded.

 

SYS@ora2lhr> exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

[ZFXDESKDB2:oracle]:/oracle>

 

 

一.11.2  开始导入

 

 

[ZFXDESKDB2:oracle]:/oracle>export ORACLE_SID=ora2lhr

[ZFXDESKDB2:oracle]:/oracle>impdp \\\’/ as sysdba \\\’ DUMPFILE=dmpfile.dmp DIRECTORY=DATA_PUMP_DIR TRANSPORT_DATAFILES=\’+DATA/ora2lhr/datafile/APP1TBS.265.902757483\’,\’+DATA/ora2lhr/datafile/APP2TBS.264.902757485\’,\’+DATA/ora2lhr/datafile/IDXTBS.262.902757485\’ LOGFILE=impdp_tts_20160202.log

 

Import: Release 11.2.0.4.0 – Production on Tue Feb 2 14:11:57 2016

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

Master table \”SYS\”.\”SYS_IMPORT_TRANSPORTABLE_01\” successfully loaded/unloaded

Starting \”SYS\”.\”SYS_IMPORT_TRANSPORTABLE_01\”:  \”/******** AS SYSDBA\” DUMPFILE=dmpfile.dmp DIRECTORY=DATA_PUMP_DIR TRANSPORT_DATAFILES=+DATA/ora2lhr/datafile/APP1TBS.265.902757483,+DATA/ora2lhr/datafile/APP2TBS.264.902757485,+DATA/ora2lhr/datafile/IDXTBS.262.902757485 LOGFILE=impdp_tts_20160202.log

Processing object type TRANSPORTABLE_EXPORT/PLUGTS_BLK

Processing object type TRANSPORTABLE_EXPORT/TABLE

Processing object type TRANSPORTABLE_EXPORT/INDEX/INDEX

Processing object type TRANSPORTABLE_EXPORT/INDEX_STATISTICS

Processing object type TRANSPORTABLE_EXPORT/TABLE_STATISTICS

Processing object type TRANSPORTABLE_EXPORT/POST_INSTANCE/PLUGTS_BLK

Job \”SYS\”.\”SYS_IMPORT_TRANSPORTABLE_01\” successfully completed at Tue Feb 2 14:12:11 2016 elapsed 0 00:00:07

 

[ZFXDESKDB2:oracle]:/oracle>

 

日志:

Tue Feb 02 14:12:04 2016

DM00 started with pid=45, OS id=25231610, job SYS.SYS_IMPORT_TRANSPORTABLE_01

Tue Feb 02 14:12:06 2016

DW00 started with pid=48, OS id=21430384, wid=1, job SYS.SYS_IMPORT_TRANSPORTABLE_01

Plug in tablespace APP1TBS with datafile

  \’+DATA/ora2lhr/datafile/APP1TBS.265.902757483\’

Plug in tablespace APP2TBS with datafile

  \’+DATA/ora2lhr/datafile/APP2TBS.264.902757485\’

Plug in tablespace IDXTBS with datafile

  \’+DATA/ora2lhr/datafile/IDXTBS.262.902757485\’

 

一.11.3  查看目标平台信息

 

[ZFXDESKDB2:oracle]:/oracle>sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.4.0 Production on Tue Feb 2 14:13:50 2016

 

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

 

 

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 – 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

 

SYS@ora2lhr> select tablespace_name,status from dba_tablespaces;

 

TABLESPACE_NAME                STATUS

—————————— ———

SYSTEM                         ONLINE

SYSAUX                         ONLINE

UNDOTBS1                       ONLINE

TEMP                           ONLINE

USERS                          ONLINE

EXAMPLE                        ONLINE

APP1TBS                        READ ONLY

APP2TBS                        READ ONLY

IDXTBS                         READ ONLY

 

9 rows selected.

 

SYS@ora2lhr> alter tablespace APP1TBS read write;

 

Tablespace altered.

 

SYS@ora2lhr> alter tablespace APP2TBS read write;

 

Tablespace altered.

 

SYS@ora2lhr> alter tablespace IDXTBS read write;

 

Tablespace altered.

 

SYS@ora2lhr> alter user user_app1 default tablespace app1tbs;

 

User altered.

 

SYS@ora2lhr> alter user user_app2 default tablespace app2tbs;

 

User altered.

 

SYS@ora2lhr>  SELECT d.username,d.default_tablespace FROM dba_users d where d.username like \’USER_%\’ ;

 

USERNAME                       DEFAULT_TABLESPACE

—————————— ——————————

USER_APP2                      APP2TBS

USER_APP1                      APP1TBS

 

SYS@ora2lhr>

 

 

 

一.12  查看导入后结果

SYS@ora2lhr> set line 9999 pagesize 9999

SYS@ora2lhr> select * from user_app1.app1_tab;

 

     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO

———- ———- ——— ———- ——————- ———- ———- ———-

      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20

      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30

      7521 WARD       SALESMAN        7698 1981-02-22 00:00:00       1250        500         30

      7566 JONES      MANAGER         7839 1981-04-02 00:00:00       2975                    20

      7654 MARTIN     SALESMAN        7698 1981-09-28 00:00:00       1250       1400         30

      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30

      7782 CLARK      MANAGER         7839 1981-06-09 00:00:00       2450                    10

      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10

      7844 TURNER     SALESMAN        7698 1981-09-08 00:00:00       1500          0         30

      7900 JAMES      CLERK           7698 1981-12-03 00:00:00        950                    30

      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20

      7934 MILLER     CLERK           7782 1982-01-23 00:00:00       1300                    10

 

12 rows selected.

 

SYS@ora2lhr> select * from user_app2.app2_tab;

 

    DEPTNO DNAME          LOC

———- ————– ————-

        10 ACCOUNTING     NEW YORK

        20 RESEARCH       DALLAS

        30 SALES          CHICAGO

        40 OPERATIONS     BOSTON

 

SYS@ora2lhr>  select D.owner,D.index_name,D.table_name,D.tablespace_name from dba_indexes d WHERE d.table_name in (\’APP1_TAB\’,\’APP2_TAB\’);

 

OWNER                          INDEX_NAME                     TABLE_NAME                     TABLESPACE_NAME

—————————— —————————— —————————— ——————————

USER_APP2                      IDX_DEPT_DNAME                 APP2_TAB                       IDXTBS

USER_APP1                      IDX_EMP_ENAME                  APP1_TAB                       IDXTBS

 

SYS@ora2lhr> SELECT   a.NAME,  b.NAME FROM v$tablespace a , v$datafile b WHERE a.TS#=b.TS#  ;

 

NAME                           NAME

—————————— ——————————————————————————–

SYSTEM                         +DATA/ora2lhr/datafile/system.335.902674033

SYSAUX                         +DATA/ora2lhr/datafile/sysaux.336.902674033

UNDOTBS1                       +DATA/ora2lhr/datafile/undotbs1.337.902674033

USERS                          +DATA/ora2lhr/datafile/users.338.902674033

EXAMPLE                        +DATA/ora2lhr/datafile/example.348.902674109

APP1TBS                        +DATA/ora2lhr/datafile/app1tbs.350.902674809

APP2TBS                        +DATA/ora2lhr/datafile/app2tbs.351.902674809

IDXTBS                         +DATA/ora2lhr/datafile/idxtbs.352.902674811

 

8 rows selected.

 

SYS@ora2lhr>

 

 

至此说明3个表空间已经完全由Linux平台迁移到AIX平台上。

 

 

 

 

 

 

————————————————————————————————————-

 

 

一.13  总结

 

到此所有的处理算是基本完毕,过程很简单,但是不同的场景处理方式有很多种,我们应该学会灵活变通。

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » 【TTS】传输表空间Linux ->AIX 基于rman