Upgrade 11203 DB to 11204 Using RMAN
We recently had an application requirement when the source 11203 database was needed by application team on different server with different name. Also the the database needs to upgraded from 11203 to 11204.
Following note describes the steps one needs to take this kind of exercise.
SOURCE DB 11.2.0.3 - NWK3
NEW DUPLICATE DB 11.2.0.4- NWD6A
##
## FIRST IDENTIFY THE DISKS AND DISK GROUPS NEEDED FOR THE NEW DATABASE. I USED THE EXISTING DATABASE CONFIGURATION AS TEMPLATE
##
ASMCMD [+] > lsdg NWC6A*
NWC6ADATA1
NWC6AARCH1
NWC6AARCH3
ASMCMD [+] > lsdsk -G NWC6ADATA1
Path
/dev/asmd0008
/dev/asmd0009
/dev/asmd0010
/dev/asmd0011
ASMCMD [+] > lsdsk -G NWC6AARCH1
Path
/dev/asma0011
/dev/asma0012
ASMCMD [+] > lsdsk -G NWC6AARCH3
Path
/dev/asma0013
/dev/asma0014
/dev/asma0015
/dev/asma0016
#############
## NWD6ADATA1 - check available disks for creation of disk group.
#############
select path, group_number group_#, disk_number disk_#, mount_status, header_status, state, total_mb, free_mb
from v$asm_disk where path like '/dev/asmd%' and header_status='CANDIDATE' order by path ;
PATH
--------------------------------------------------------------------------------
GROUP_# DISK_# MOUNT_S HEADER_STATU STATE TOTAL_MB FREE_MB
---------- ---------- ------- ------------ -------- ---------- ----------
/dev/asmd0012
0 28 CLOSED CANDIDATE NORMAL 0 0
/dev/asmd0013
0 29 CLOSED CANDIDATE NORMAL 0 0
/dev/asmd0014
0 30 CLOSED CANDIDATE NORMAL 0 0
/dev/asmd0015
0 31 CLOSED CANDIDATE NORMAL 0 0
#############
## NWD6AARCH3
#############
select path, group_number group_#, disk_number disk_#, mount_status, header_status, state, total_mb, free_mb
from v$asm_disk where path like '/dev/asma%' and header_status='CANDIDATE' order by path ;
PATH
--------------------------------------------------------------------------------
GROUP_# DISK_# MOUNT_S HEADER_STATU STATE TOTAL_MB FREE_MB
---------- ---------- ------- ------------ -------- ---------- ----------
/dev/asma1001
0 0 CLOSED CANDIDATE NORMAL 0 0
/dev/asma1002
0 1 CLOSED CANDIDATE NORMAL 0 0
/dev/asma1003
0 2 CLOSED CANDIDATE NORMAL 0 0
/dev/asma1004
0 3 CLOSED CANDIDATE NORMAL 0 0
#############
## NWD6AARCH1
#############
/dev/asma2001
0 4 CLOSED CANDIDATE NORMAL 0 0
/dev/asma2002
0 5 CLOSED CANDIDATE NORMAL 0 0
##
## CREATE A NEW DATA DISK GROUP FOR NWD6A DATABASE
##
CREATE DISKGROUP NWD6ADATA1 EXTERNAL REDUNDANCY
DISK '/dev/asmd0012' NAME asmd0012, '/dev/asmd0013' NAME asmd0013, '/dev/asmd0014' NAME asmd0014,'/dev/asmd0015' NAME asmd0015;
Diskgroup created.
##
## CREATE A NEW ARCH1 DISK GROUP FOR NWD6A DATABASE
##
CREATE DISKGROUP NWD6AARCH1 EXTERNAL REDUNDANCY
DISK '/dev/asma2001' NAME asma2001, '/dev/asma2002' NAME asma2002;
Diskgroup created.
##
## CREATE A NEW ARCH3 DISK GROUP FOR NWD6A DATABASE
##
CREATE DISKGROUP NWD6AARCH3 EXTERNAL REDUNDANCY
DISK '/dev/asma1001' NAME asma1001, '/dev/asma1002' NAME asma1002, '/dev/asma1003' NAME asma1003, '/dev/asma1004' NAME asma1004;
Diskgroup created.
##
## NOW PREPARE THE PARAMETER FILE. EITHER ONE CAN PREPARE THE NORMAL FILE OR ## USE THE PARAMETER FILE FROM SOURCE DATABASE
##
*.audit_file_dest='/ora47/adump/nwd6a'
*.compatible='11.2.0.3.0'
*.control_files='+NWD6ADATA1/control01.ctl','+NWD6ADATA1/control02.ctl','+NWD6ADATA1/control03.ctl'
*.db_block_size=8192
*.DB_CREATE_FILE_DEST=('+NWD6ADATA1')
*.db_domain=''
*.db_files=2000
*.db_name='nwd6a'
*.db_unique_name='nwd6a'
*.deferred_segment_creation=FALSE
*.diagnostic_dest='/ora01/app/oracle'
*.dispatchers='(PROTOCOL=TCP) (SERVICE=NWD6AXDB)'
*.log_archive_dest_1='LOCATION=+NWD6AARCH1'
*.open_cursors=300
*.os_authent_prefix=''
*.pga_aggregate_target=10670309376
*.processes=1500
*.remote_login_passwordfile='EXCLUSIVE'
*.sessions=1655
*.sga_max_size=3G
*.sga_target=3G
*.undo_tablespace='UNDOTBS1'
##
## Start the database in nomount mode..
##
< xxx : nwd6a : oracle : /users/oracle/hshah/GOLD_MAROON_FROM_TORQUISE_DONOT_DEL/nwk3_gold_cpy >
$ rman auxiliary /
connected to auxiliary database: NWD6A (not mounted)
run
{
allocate auxiliary channel c1 type disk;
allocate auxiliary channel c2 type disk;
allocate auxiliary channel c3 type disk;
allocate auxiliary channel c4 type disk;
allocate auxiliary channel c5 type disk;
DUPLICATE DATABASE TO 'nwd6a' pfile='/ora01/app/oracle/product/11.2.0.4/db_1/dbs/initnwd6a.ora'
BACKUP LOCATION '/users/oracle/hshah/GOLD_MAROON_FROM_TORQUISE_DONOT_DEL/nwk3_gold_cpy' noredo noopen
LOGFILE
GROUP 1 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 2 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 3 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 4 ('+nwd6adata1') SIZE 100M REUSE;
release channel c1;
release channel c2;
release channel c3;
release channel c4;
release channel c5;
}
##
## ISSUES THAT CAME ACROSS...
##
1/ SOURCE DISK GROUP DID NOT EXIST - diskgroup "NWK3DATA1"
ORA-15001: diskgroup "NWK3DATA1" does not exist or is not mounted
ORA-15001: diskgroup "NWK3DATA1" does not exist or is not mounted
sql statement: CREATE CONTROLFILE REUSE SET DATABASE "NWD6A" RESETLOGS NOARCHIVELOG
MAXLOGFILES 64
MAXLOGMEMBERS 3
MAXDATAFILES 1000
MAXINSTANCES 1
MAXLOGHISTORY 584
LOGFILE
GROUP 1 ( '+nwd6adata1' ) SIZE 100 M REUSE,
GROUP 2 ( '+nwd6adata1' ) SIZE 100 M REUSE,
GROUP 3 ( '+nwd6adata1' ) SIZE 100 M REUSE,
GROUP 4 ( '+nwd6adata1' ) SIZE 100 M REUSE
DATAFILE
'+NWD6ADATA1/nwd6a/datafile/system.286.877202211'
CHARACTER SET WE8ISO8859P1
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of Duplicate Db command at 04/16/2015 19:45:21
RMAN-05501: aborting duplication of target database
RMAN-06136: ORACLE error from auxiliary database: ORA-01503: CREATE CONTROLFILE failed
ORA-00349: failure obtaining block size for '+nwk3data1'
ORA-15001: diskgroup "NWK3DATA1" does not exist or is not mounted
ORA-15001: diskgroup "NWK3DATA1" does not exist or is not mounted
CAUSE - This failure happend due log_file_name_convert and db_file_name_convert parameter. Hence those paraemeters were removed.
##
## AFTER MODIFYING THE PARAMETER FILE AND REMOVING CONVERT PARAMETER, THE DUPLICATION WORKED.
##
contents of Memory Script:
{
Alter clone database open resetlogs;
}
executing Memory Script
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-00601: fatal error in recovery manager
RMAN-03004: fatal error during execution of command
RMAN-10041: Could not re-create polling channel context following failure.
RMAN-10024: error setting up for rpc polling
RMAN-10005: error opening cursor
RMAN-10002: ORACLE error: ORA-03114: not connected to ORACLE
RMAN-03002: failure of Duplicate Db command at 04/16/2015 21:19:47
RMAN-05501: aborting duplication of target database
RMAN-03015: error occurred in stored script Memory Script
RMAN-06136: ORACLE error from auxiliary database: ORA-01092: ORACLE instance terminated. Disconnection forced
ORA-00704: bootstrap process failure
ORA-39700: database must be opened with UPGRADE option
Process ID: 29360134
Session ID: 3 Serial number: 5
##
## MADE CHANGES TO SCRIPT FOR NOREDO AND NOOPEN
## CHANGED THE LOCATION FOR THE ONLINE LOGFILE
##
$ rman auxiliary /
connected to auxiliary database: NWD6A (not mounted)
run
{
allocate auxiliary channel c1 type disk;
allocate auxiliary channel c2 type disk;
allocate auxiliary channel c3 type disk;
allocate auxiliary channel c4 type disk;
allocate auxiliary channel c5 type disk;
DUPLICATE DATABASE TO 'nwd6a' pfile='/ora01/app/oracle/product/11.2.0.4/db_1/dbs/initnwd6a.ora'
BACKUP LOCATION '/users/oracle/hshah/GOLD_MAROON_FROM_TORQUISE_DONOT_DEL/nwk3_gold_cpy' noredo noopen
LOGFILE
GROUP 1 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 2 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 3 ('+nwd6adata1') SIZE 100M REUSE,
GROUP 4 ('+nwd6adata1') SIZE 100M REUSE;
release channel c1;
release channel c2;
release channel c3;
release channel c4;
release channel c5;
}
##
## AFTER RUNNING THE DUPLICATE WITH NOREDO AND NO OPEN THE DUPLICATE WENT
## FINE...
##
datafile 22 switched to datafile copy
input datafile copy RECID=21 STAMP=877251535 file name=+NWD6ADATA1/nwd6a/datafile/i_dmrep.278.877250233
Leaving database unopened, as requested
Finished Duplicate Db at 17-APR-15
2. Issue with UNDO TABLE SPACE
SQL> startup nomount;
ORACLE instance started.
Total System Global Area 2137886720 bytes
Fixed Size 2248080 bytes
Variable Size 1442841200 bytes
Database Buffers 687865856 bytes
Redo Buffers 4931584 bytes
SQL> CREATE CONTROLFILE REUSE SET DATABASE "NWD6A" RESETLOGS NOARCHIVELOG
2 MAXLOGFILES 64
3 MAXLOGMEMBERS 3
4 MAXDATAFILES 1000
MAXINSTANCES 1
5 6 MAXLOGHISTORY 584
7 LOGFILE
8 GROUP 1 ( '+nwd6adata1' ) SIZE 100 M REUSE,
9 GROUP 2 ( '+nwd6adata1' ) SIZE 100 M REUSE,
10 GROUP 3 ( '+nwd6adata1' ) SIZE 100 M REUSE,
11 GROUP 4 ( '+nwd6adata1' ) SIZE 100 M REUSE
12 DATAFILE
'+NWD6ADATA1/nwd6a/datafile/system.286.877202211'
13 14 CHARACTER SET WE8ISO8859P1
15 ;
SQL> spool upgrade.log
SQL> alter database open resetlogs upgrade;
alter database open resetlogs upgrade
*
ERROR at line 1:
ORA-01092: ORACLE instance terminated. Disconnection forced
ORA-30046: Undo tablespace UNDO1 not found in control file.
Process ID: 32571418
Session ID: 298 Serial number: 1
##
## AFTER THE RESTORE AND RECOVERY DONE, STOP & START THE DUPLICATED DATABASE.
## CHECK FOR TEMP FILES AND LOG FILES.
##
SQL> select * from gv$tempfile;
INST_ID FILE# CREATION_CHANGE# CREATION_ TS# RFILE# STATUS ENABLED BYTES BLOCKS CREATE_BYTES BLOCK_SIZE NAME
---------- ---------- ---------------- --------- ---------- ---------- ------- ---------- ---------- ---------- ------------ ----------
1 1 5.6483E+12 21-JAN-14 3 1 ONLINE READ WRITE 0 0 9663676416 8192 +NWD6ADATA1
1 2 5.6479E+12 10-MAY-13 3 2 ONLINE READ WRITE 0 0 2147483648 8192 +NWD6ADATA1
##
## OPEN THE DB IN UPGRADE MODE.
##
SQL> alter database open resetlogs upgrade ;
Database altered.
SQL> select instance_name,status from v$instance;
INSTANCE_NAME STATUS
---------------- ------------
nwd6a OPEN MIGRATE
##
## RUN THE UPGRADE SCRIPT.
##
sql > @$ORACLE_HOME/rdbms/admin/catupgrd.sql
SQL> @$ORAC1120/rdbms/admin'UTLU112S.SQL;
SQL> @$ORA11202/RDBMS/ADMIN/CATUPPST.SQL
SQL> @$ORAC1120/rdbms/admin/utlrp.sql;
##
## AFTER UPGRADE OPEN THE DATABASE IN OPEN MODE
##
SQL> startup
ORACLE instance started.
Total System Global Area 3206836224 bytes
Fixed Size 2250648 bytes
Variable Size 1174407272 bytes
Database Buffers 2013265920 bytes
Redo Buffers 16912384 bytes
Database mounted.
Database opened.
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE 11.2.0.4.0 Production
TNS for IBM/AIX RISC System/6000: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
##
## RECREATE SPFILE ON ASM
##
$ cat initnwd6a.ora
SPFILE='+nwd6adata1/nwd6a/parameterfile/spfile.257.877255249'
##
## ADD DATABASE TO OCR AS CRS RESOURCE
##
$ srvctl add database -d nwd6a -o /ora01/app/oracle/product/11.2.0.4/db_1 -p '+nwd6adata1/nwd6a/parameterfile/spfile.257.877255249' -s OPEN -t NORMAL -y AUTOMATIC -a "nwd6adata1,nwd6aarch1,nwd6aarch3"
$ srvctl start database -d nwd6a
< rri2rxodda201 : nwd6a : oracle : /ora01/app/oracle/product/11.2.0.4/db_1/dbs >
$ srvctl status database -d nwd6a
Database is running.
SQL> create or replace directory EXPDP as '/ora49/dpdump/nwd6a' ;
Directory created.
Once you are done, your database is ready to roll...