In this example, I have two databases. My original database called "FRAN" and my target database called "duplicate". I have created duplicate with dbca, it is empty. I want to clone Fran into duplicated to do my tests without modify any important data of FRAN database.
1)First of all I need to do a full backup of FRAN:
2) You should know path of datafiles, logfiles, tempfiles, dbid, and a copy of pfile (for security):
- To know where are datafiles, logfiles and tempfiles execute this query:
SQLPLUS> SELECT FILE# AS
"File/Grp#", NAME
FROM V$DATAFILE
UNION
SELECT GROUP#,MEMBER
FROM V$LOGFILE
UNION
SELECT FILE#, NAME
FROM V$TEMPFILE;
-To make a copy of FRAN's pfile:
SQLPLUS> create pfile='<path>/PFILE_ORIGINAL' from spfile;
-To know FRAN's DBID
when we run rman, appear--> Connected to target database: <database_name>(DBID XXXXXXX)
3) copy backup database in the same directory of target server, I mean if we have in FRAN's Server the bakcup in '/backup/rman/' we should have the same directory into DUPLICATE server and copy the backup there.
If it is in the same server, don't do anything.
If not you should move between servers with scp <backup_direcotry> <user>@<SERVER_IP/NAME>:<target_diretctory> . In example:
$ scp /backup/rman/% oracle@DUPLICATEDB:/backup/rman/
4) To duplicate, we have to put DUPLICATEDB into NOMOUNT state:
5) Now create duplicate script, we have two choices, with exactly the same name and path of datafiles/logfiles/tempfiles, or with different name or path or both:
IMPORTANT: run the next step from SOURCE server, in that case FRAN's server.
IMPORTANT_2: databases name are stored with 8 digits, so DUPLICATE will be DUPLICAT. I will use this alias, because if you use real name, you will get error. Also if you execute in sqlplus "select name from v$database" will show DUPLICAT, DUPLICATE doesn't show but it is the database real name. Take care with the name used, the good one is 8 digits.
5.1) exactly the same datafiles/logfiles/tempfiles name and path
$duplicate_db> rman target system/<passwd>@FRAN auxiliary /
RMAN>
run{-To know FRAN's DBID
when we run rman, appear--> Connected to target database: <database_name>(DBID XXXXXXX)
3) copy backup database in the same directory of target server, I mean if we have in FRAN's Server the bakcup in '/backup/rman/' we should have the same directory into DUPLICATE server and copy the backup there.
If it is in the same server, don't do anything.
If not you should move between servers with scp <backup_direcotry> <user>@<SERVER_IP/NAME>:<target_diretctory> . In example:
$ scp /backup/rman/% oracle@DUPLICATEDB:/backup/rman/
4) To duplicate, we have to put DUPLICATEDB into NOMOUNT state:
5) Now create duplicate script, we have two choices, with exactly the same name and path of datafiles/logfiles/tempfiles, or with different name or path or both:
IMPORTANT: run the next step from SOURCE server, in that case FRAN's server.
IMPORTANT_2: databases name are stored with 8 digits, so DUPLICATE will be DUPLICAT. I will use this alias, because if you use real name, you will get error. Also if you execute in sqlplus "select name from v$database" will show DUPLICAT, DUPLICATE doesn't show but it is the database real name. Take care with the name used, the good one is 8 digits.
5.1) exactly the same datafiles/logfiles/tempfiles name and path
$duplicate_db> rman target system/<passwd>@FRAN auxiliary /
RMAN>
duplicate target database to 'DUPLICAT' nofilenamecheck;
}
5.2) different datafiles/logfiles/tempfiles name ond path or both:
SET NEWNAME FOR DATAFILE '<ORIGINAL_PATH/DATAFILE_NAME>' TO '<NEW_PATH/NEW_DATAFILE_NAME>';
RMAN>
run{
SET NEWNAME FOR DATAFILE '<ORIGINAL_PATH/ORIGINAL_DATAFILE_NAME_1>' TO '<NEW_PATH/NEW_DATAFILE_NAME_1>';
DUPLICATE TARGET DATABASE TO ‘DUPLICAT’;
SET NEWNAME FOR DATAFILE <ORIGINAL_PATH/ORIGINAL_DATAFILE_NAME_1> TO '<NEW_PATH/NEW_DATAFILE_NAME_1>';
SET NEWNAME FOR DATAFILE <ORIGINAL_PATH/ORIGINAL_DATAFILE_NAME_1> TO '<NEW_PATH/NEW_DATAFILE_NAME_1>';
*
*
*
SET NEWNAME FOR TEMPFILE<ORIGINAL_PATH/ORIGINAL_TEMPFILE_NAME> TO '<NEW_PATH/NEW_TEMPFILE_NAME>';
SET NEWNAME FOR TEMPFILE<ORIGINAL_PATH/ORIGINAL_TEMPFILE_NAME> TO *
*
*
*
SET NEWNAME FOR LOGFILE<ORIGINAL_PATH/LOGFILE_NAME> TO '<NEW_PATH/NEW_LOGFILE_NAME>';
*
*
*
*
*
DUPLICATE TARGET DATABASE TO "DUPLICAT";
}
*If you omit something, oracle will deduce that you want with the same path+name, for example it could be just one logfile or all tempfiles.
** you can add in that script: PFILE, CONTROLFILE too
6) I will choose different name and path for datafiles and tempfiles, so from Fran's server I execute:
remember --> auxiliary will be DUPLICAT (new database) with nomount state and target is FRAN (original database) with open state.
*when duplicate finish, DUPLICAT database will be called like original database (Fran) with same DBID of Original Fran.
That's all!!
No hay comentarios:
Publicar un comentario