rman clone NID 新创建数据文件从0开始恢复

How to clone/duplicate a database with added datafile with no backup

Oracle Database - Enterprise Edition - Version 9.2.0.1 to 10.2.0.4 [Release 9.2 to 10.2]

Information in this document applies to any platform.

GOAL

How can I clone/duplicate a database and change it's name if a datafile backup is missing. Archivelog files are available for recreating the datafile using 'alter database create datafile'.

I.e., a datafile was added to the database, but not yet backed up. Archive files are available to recreate this datafile. How can a clone/duplicate database be created in this scenario?

Issues to consider:

  1. The RMAN duplicate command will want to create a new controlfile. However, the new datafile will not be added to the controlfile.

  2. If a new controlfile is created with a database name change, the datafile cannot be added after the fact.

  3. You cannot create a datafile (using alter database) if that datafile is not listed in the controlfile.

SOLUTION

You will not be able to use the RMAN duplicate in this scenario. The RMAN duplicate command would fail with errors on the newly added datafile, like:

ORA-01503: CREATE CONTROLFILE failed

ORA-01565: error in identifying file '/<path>/<filename>'

ORA-27041: unable to open file

OSD-04002: unable to open file

O/S-Error: (OS 2) The system cannot find the file specified.

Another possibility would be errors like:

RMAN-03002: failure of Duplicate Db command at 03/22/2007 10:16:22

RMAN-03015: error occurred in stored script Memory Script

ORA-00283: recovery session canceled due to errors

RMAN-11003: failure during parse/execution of SQL statement: alter database recover logfile '/<path>/<archivelog_name>'

ORA-00283: recovery session canceled due to errors

ORA-01244: unnamed datafile(s) added to controlfile by media recovery

ORA-01110: data file 93: '/<path>/<filename>'

NOTE: In Oracle10g, RMAN will create the datafiles on recovery, so this may not be an issue.

NOTE: The same issue can apply to creating a duplicate database for standby, when datafiles are added to the primary after the backup.

Instead, you MUST use a current controlfile of the target database, to create the clone. Then the database name/DBID can be changed using the NID utility.

STEPS:

NOTE: Target database must be shutdown if the clone is created on the same server.

  1. copy production controlfile in the clone location.

  2. startup mount clone database

  3. select name from v$datafile

-- issue 'alter database rename file .... to .....; /* this renames the datafile location. It is

must be issued for every datafile existing - thus missing datafile will not be included in this

rename.

  1. select name from v$logfile

-- issue ''alter database rename file .... to .....; /* this rename will place the redo log files

in the proper location when clone database is opened.

  1. issue:

alter database create datafile AS;

  1. Restore the database

  2. recover database using backup controlfile until cancel;

-- apply all archives you have

  1. alter database open resetlogs;

  2. shutdown database

  3. startup mount

  4. exit sql and issue at the operating system:

-- nid TARGET=SYS/<PASSWORD> DBNAME SETNAME=YES

/* NOTE: If you plan to register this database in RMAN the dbid must also be changed using the NID utility */

  1. shutdown database

  2. edit init.ora changing db_name parameter

  3. startup cloned database

  4. verify name change:

select name from v$database

show parameter db_name

相关推荐
power 雀儿2 分钟前
集群聊天服务器---MySQL数据库的建立
服务器·数据库·mysql
骑着王八撵玉兔2 小时前
【性能优化与架构调优(二)】高性能数据库设计与优化
数据库·性能优化·架构
想要入门的程序猿3 小时前
Qt写入excel
数据库·qt·excel
Q_970956393 小时前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
Wyc724093 小时前
Maven
java·数据库·maven
程序猿小D3 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站
羊小猪~~3 小时前
数据库学习笔记(十七)--触发器的使用
数据库·人工智能·后端·sql·深度学习·mysql·考研
背太阳的牧羊人4 小时前
Neo4j 的向量搜索(Neo4jVector)和常见的向量数据库(比如 Milvus、Qdrant)之间的区别与联系
数据库·neo4j·milvus
liulun4 小时前
在浏览器中使用SQLite(官方sqlite3.wasm)
数据库·sqlite·wasm
IT项目管理6 小时前
达梦数据库DMHS介绍及安装部署
linux·数据库