0

0

RMAN 异机迁移

php中文网

php中文网

发布时间:2016-06-07 17:20:41

|

1110人浏览过

|

来源于php中文网

原创

目标库准备实例名准备:此实例名为原库的实例名。 不要随意设, 因控制文件里是有记录DB_NAME的, 如果你随便设置实例名,是没办

1. 环境说明:
原机:192.168.102.156     oracle 10.2.0.1
目标:192.168.102.157     oracle 10.2.0.1
2.对数据库做创建一张表。
sql> create table rmantest(id number(9));
table created.
sql> insert into rmantest(id) values(88);
1 row created.
sql> commit;
commit complete.
sql> alter system switch logfile;
system altered.
3. 目标库准备实例名准备:此实例名为原库的实例名。 不要随意设, 因控制文件里是有记录db_name的, 如果你随便设置实例名,是没办法完成迁移的。
[oracle@goldengate2 ~]$ export oracle_sid=gg1
[oracle@goldengate2 ~]$ echo $oracle_sid
gg1
4. 目标库准备参数文件。
(1) 在原库创建一个pfile文件。
sql> create pfile='/home/oracle/initgg1.ora' from spfile;
file created.
(2) 奖参数文件移至目标库。
[oracle@goldengate1 ~]$ scp initgg1.oraoracle@192.168.102.157:/home/oracle
oracle@192.168.102.157'spassword:
initgg1.ora                                                                                                100% 1051     1.0kb/s   00:00
5. 在目标库创建参数文件中所需要的目录。
[oracle@goldengate2 ~]$ mkdir -p admin/gg1/adump
[oracle@goldengate2 ~]$ mkdir -p admin/gg1/bdump
[oracle@goldengate2 ~]$ mkdir -p admin/gg1/cdump
[oracle@goldengate2 ~]$ mkdir -p admin/gg1/dpdump
[oracle@goldengate2 ~]$ mkdir -p admin/gg1/udump
[oracle@goldengate2 ~]$ mkdir flash_recovery_area
[oracle@goldengate2 ~]$ mkdir -p oradata/gg1
[oracle@goldengate2 ~]$ mkdir archivelog
6. 在目标库创建spfile文件,并将数据库启动到nomount状态。
[oracle@goldengate2 ~]$ export oracle_sid=gg1
[oracle@goldengate2 ~]$ sqlplus / as sysdba
sql*plus: release 10.2.0.1.0 - production on fri sep 21 01:21:51 2012
copyright (c) 1982, 2005, oracle.  all rights reserved.
connected to an idle instance.
sql> create spfile from pfile='/home/oracle/initgg1.ora';
file created.
sql> startup nomount;
oracle instance started.
total system global area  167772160 bytes
fixed size                  1218292 bytes
variable size              83888396 bytes
database buffers           75497472 bytes
redo buffers                7168000 bytes
 
7. 对原数据库进行热备份。 必备条件: 数据库属归档模式。
[oracle@goldengate1 ~]$ rman target /
recovery manager: release 10.2.0.1.0 - production on fri sep 21 01:21:49 2012
copyright (c) 1982, 2005, oracle.  all rights reserved.
connected to target database: gg1 (dbid=1620494887)
rman>  run{
allocate channel a1 type disk;
allocate channel a2 type disk;
backup format='/home/oracle/rman/full_%d_%t_%s'  database;
backup format='/home/oracle/rman/arch_%d_%t_%s' archivelog all;
backup format='/home/oracle/rman/ctl_%u' current controlfile;
release channel a2;
 release channel a1;
}2> 3> 4> 5> 6> 7> 8> 9>
released channel: ora_disk_1
allocated channel: a1
channel a1: sid=158 devtype=disk
allocated channel: a2
channel a2: sid=141 devtype=disk
starting backup at 21-sep-12
channel a1: starting full datafile backupset
channel a1: specifying datafile(s) in backupset
input datafile fno=00001 name=/home/oracle/oradata/gg1/system01.dbf
input datafile fno=00005 name=/home/oracle/oradata/gg1/example01.dbf
input datafile fno=00003 name=/home/oracle/oradata/gg1/sysaux01.dbf
channel a1: starting piece 1 at 21-sep-12
channel a2: starting full datafile backupset
channel a2: specifying datafile(s) in backupset
input datafile fno=00006 name=/home/oracle/oradata/gg1/gg01.dbf
input datafile fno=00002 name=/home/oracle/oradata/gg1/undotbs01.dbf
input datafile fno=00004 name=/home/oracle/oradata/gg1/users01.dbf
channel a2: starting piece 1 at 21-sep-12
channel a2: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/full_gg1_20120921_10 tag=tag20120921t013222 comment=none
channel a2: backup set complete, elapsed time: 00:00:25
channel a2: starting full datafile backupset
channel a2: specifying datafile(s) in backupset
including current control file in backupset
channel a2: starting piece 1 at 21-sep-12
channel a2: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/full_gg1_20120921_11 tag=tag20120921t013222 comment=none
channel a2: backup set complete, elapsed time: 00:00:03
channel a2: starting full datafile backupset
channel a2: specifying datafile(s) in backupset
including current spfile in backupset
channel a2: starting piece 1 at 21-sep-12
channel a2: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/full_gg1_20120921_12 tag=tag20120921t013222 comment=none
channel a2: backup set complete, elapsed time: 00:00:02
channel a1: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/full_gg1_20120921_9 tag=tag20120921t013222 comment=none
channel a1: backup set complete, elapsed time: 00:00:48
finished backup at 21-sep-12
starting backup at 21-sep-12
current log archived
channel a1: starting archive log backupset
channel a1: specifying archive log(s) in backup set
input archive log thread=1 sequence=4 recid=1 stamp=794527523
channel a1: starting piece 1 at 21-sep-12
channel a2: starting archive log backupset
channel a2: specifying archive log(s) in backup set
input archive log thread=1 sequence=5 recid=2 stamp=794538401
input archive log thread=1 sequence=6 recid=3 stamp=794539337
input archive log thread=1 sequence=7 recid=4 stamp=794539385
channel a2: starting piece 1 at 21-sep-12
channel a2: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/arch_gg1_20120921_13 tag=tag20120921t013312 comment=none
channel a2: backup set complete, elapsed time: 00:00:02
channel a1: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/arch_gg1_20120921_14 tag=tag20120921t013312 comment=none
channel a1: backup set complete, elapsed time: 00:00:03
channel a2: starting archive log backupset
channel a2: specifying archive log(s) in backup set
input archive log thread=1 sequence=8 recid=5 stamp=794539992
channel a2: starting piece 1 at 21-sep-12
channel a2: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/arch_gg1_20120921_15 tag=tag20120921t013312 comment=none
channel a2: backup set complete, elapsed time: 00:00:02
finished backup at 21-sep-12
starting backup at 21-sep-12
channel a1: starting full datafile backupset
channel a1: specifying datafile(s) in backupset
including current control file in backupset
channel a1: starting piece 1 at 21-sep-12
channel a1: finished piece 1 at 21-sep-12
piece handle=/home/oracle/rman/ctl_0gnlndut_1_1 tag=tag20120921t013317 comment=none
channel a1: backup set complete, elapsed time: 00:00:02
finished backup at 21-sep-12
released channel: a2
released channel: a1
8. 将备份移至目标机。
[oracle@goldengate1 ~]$ cd rman/
[oracle@goldengate1 rman]$ ls
arch_gg1_20120921_13  arch_gg1_20120921_15  full_gg1_20120921_10  full_gg1_20120921_12
arch_gg1_20120921_14  ctl_0gnlndut_1_1      full_gg1_20120921_11  full_gg1_20120921_9
[oracle@goldengate1 rman]$ scp *oracle@192.168.102.157:/home/oracle/rman
oracle@192.168.102.157'spassword:
arch_gg1_20120921_13                                                                                       100%   13mb  12.8mb/s   00:01  
arch_gg1_20120921_14                                                                                       100%   25mb  12.5mb/s   00:02  
arch_gg1_20120921_15                                                                                       100%  281kb 281.0kb/s   00:00  
ctl_0gnlndut_1_1                                                                                           100% 6944kb   6.8mb/s   00:00  
full_gg1_20120921_10                                                                                       100%   33mb   8.2mb/s   00:04  
full_gg1_20120921_11                                                                                       100% 6944kb   6.8mb/s   00:00  
full_gg1_20120921_12                                                                                       100%   96kb  96.0kb/s   00:01  
full_gg1_20120921_9                                                                                        100%  561mb  11.9mb/s   00:47  
9. 在目标机上恢复控制文件。
[oracle@goldengate2 rman]$ rman target /
recovery manager: release 10.2.0.1.0 - production on fri sep 21 01:36:10 2012
copyright (c) 1982, 2005, oracle.  all rights reserved.
connected to target database: gg1 (not mounted)
rman> restore controlfile from '/home/oracle/rman/ctl_0gnlndut_1_1';
starting restore at 21-sep-12
using target database control file instead of recovery catalog
allocated channel: ora_disk_1
channel ora_disk_1: sid=156 devtype=disk
channel ora_disk_1: restoring control file
channel ora_disk_1: restore complete, elapsed time: 00:00:03
output filename=/home/oracle/oradata/gg1/control01.ctl
output filename=/home/oracle/oradata/gg1/control02.ctl
output filename=/home/oracle/oradata/gg1/control03.ctl
finished restore at 21-sep-12
10. 启动数据库到mount状态。
rman> alter database mount;
database mounted
released channel: ora_disk_1
11.恢复数据库。
rman> restore database;
starting restore at 21-sep-12
starting implicit crosscheck backup at 21-sep-12
allocated channel: ora_disk_1
channel ora_disk_1: sid=156 devtype=disk
crosschecked 7 objects
finished implicit crosscheck backup at 21-sep-12
starting implicit crosscheck copy at 21-sep-12
using channel ora_disk_1
finished implicit crosscheck copy at 21-sep-12
searching for all files in the recovery area
cataloging files...
no files cataloged
using channel ora_disk_1
channel ora_disk_1: starting datafile backupset restore
channel ora_disk_1: specifying datafile(s) to restore from backup set
restoring datafile 00002 to /home/oracle/oradata/gg1/undotbs01.dbf
restoring datafile 00004 to /home/oracle/oradata/gg1/users01.dbf
restoring datafile 00006 to /home/oracle/oradata/gg1/gg01.dbf
channel ora_disk_1: reading from backup piece /home/oracle/rman/full_gg1_20120921_10
channel ora_disk_1: restored backup piece 1
piece handle=/home/oracle/rman/full_gg1_20120921_10 tag=tag20120921t013222
channel ora_disk_1: restore complete, elapsed time: 00:00:15
channel ora_disk_1: starting datafile backupset restore
channel ora_disk_1: specifying datafile(s) to restore from backup set
restoring datafile 00001 to /home/oracle/oradata/gg1/system01.dbf
restoring datafile 00003 to /home/oracle/oradata/gg1/sysaux01.dbf
restoring datafile 00005 to /home/oracle/oradata/gg1/example01.dbf
channel ora_disk_1: reading from backup piece /home/oracle/rman/full_gg1_20120921_9
channel ora_disk_1: restored backup piece 1
piece handle=/home/oracle/rman/full_gg1_20120921_9 tag=tag20120921t013222
channel ora_disk_1: restore complete, elapsed time: 00:00:35
finished restore at 21-sep-12
rman> recover database;
starting recover at 21-sep-12
using channel ora_disk_1
starting media recovery
channel ora_disk_1: starting archive log restore to default destination
channel ora_disk_1: restoring archive log
archive log thread=1 sequence=8
channel ora_disk_1: reading from backup piece /home/oracle/rman/arch_gg1_20120921_15
channel ora_disk_1: restored backup piece 1
piece handle=/home/oracle/rman/arch_gg1_20120921_15 tag=tag20120921t013312
channel ora_disk_1: restore complete, elapsed time: 00:00:02
archive log filename=/home/oracle/archivelog/1_8_794474474.dbf thread=1 sequence=8
unable to find archive log
archive log thread=1 sequence=9
rman-00571: ===========================================================
rman-00569: =============== error message stack follows ===============
rman-00571: ===========================================================
rman-03002: failure of recover command at 09/21/2012 01:38:18
rman-06054: media recovery requesting unknown log: thread 1 seq 9 lowscn 529513
查看原库日志:
[oracle@goldengate1 archivelog]$ ls
1_4_794474474.dbf  1_5_794474474.dbf  1_6_794474474.dbf  1_7_794474474.dbf  1_8_794474474.dbf
[oracle@goldengate1 archivelog]$
干, 这里就没有那日志。
因为原库并未生成seq为9的日志,这里根本就没有9的备份。
用sqlplus连进行执行恢复。
sql> recover database using backup controlfile;
ora-00279: change 529513 generated at 09/21/2012 01:33:11 needed for thread 1
ora-00289: suggestion : /home/oracle/archivelog/1_9_794474474.dbf
ora-00280: change 529513 for thread 1 is in sequence #9
 
specify log: {=suggested | filename | auto | cancel}
cancel
media recovery cancelled.
12。 打开数据库。
sql> alter database open resetlogs;
alter database open resetlogs
*
error at line 1:
ora-01113: file 1 needs media recovery
ora-01110: data file 1: '/home/oracle/oradata/gg1/system01.dbf'
因为控制文件和数据文件不一致。
解决办法:
修改参数文件:增加 _allow_resetlogs_corruption='ture'
关闭数据库,重建spfile文件,,并启动到nomount状态。
打开数据库:
sql> alter database open resetlogs;
database altered.
13。 检查
redo日志和临时表空间文件会在打开数据库时根据控制文件中的记录去创建。
查看原库所建的表:
sql> select * from rmantest;
        id
----------
        88
迁移完成。

linux

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 序列化
Python 序列化

本专题整合了python序列化、反序列化相关内容,阅读专题下面的文章了解更多详细内容。

12

2026.02.02

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

200

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

98

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

15

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

16

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

9

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

62

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

56

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

28

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.4万人学习

Django 教程
Django 教程

共28课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号