Have you ever faced the situation where you need to recover a database with missing archives, and because of that Oracle won't let you open the database?
Here is an excelent article explaining what to do.
HTH,
Inaki
In this blog I will publish short tips that can make life easier to the crowd of Oracle DBA's around the world (at least in my intention).
Wednesday, March 14, 2012
Sunday, March 11, 2012
Clone your production database to a test environment
My first post will show you the steps to prepare and run a script to automatically duplicate an Oracle Database. This is a very useful setup when you need a clone of your production database for testing purposes on a regular basis.
I'll be using as a example the following config:
-Source database: PRODDB on host PROD
-Destination database: TESTDB on host TEST
-Oracle database 10g/11g with ASM
-Backup and archived redo logs of PRODDB on a nfs location accessible from the two hosts (not needed if using FROM ACTIVE DATABASE option)
-PRODDB database uses a catalog for rman backups.
- ASM has two diskgroups: FLASH (for FLASH RECOVERY AREA) and DATA (for regular database files) on both hosts. ASM owner is the same as db owner.
1. Put a static entry in listener.ora of TEST host
2. Put an entry in tnsnames.ora file of both hosts for the two databases
On host PROD:
I'll be using as a example the following config:
-Source database: PRODDB on host PROD
-Destination database: TESTDB on host TEST
-Oracle database 10g/11g with ASM
-Backup and archived redo logs of PRODDB on a nfs location accessible from the two hosts (not needed if using FROM ACTIVE DATABASE option)
-PRODDB database uses a catalog for rman backups.
- ASM has two diskgroups: FLASH (for FLASH RECOVERY AREA) and DATA (for regular database files) on both hosts. ASM owner is the same as db owner.
1. Put a static entry in listener.ora of TEST host
SID_LIST_LISTENER =
    (SID_LIST =
      (SID_DESC =
         (SID_NAME = +ASM)
         (SERVICE_NAME = +ASM)
         (ORACLE_HOME = /u01/app/oracle/product/11.2.0.3/grid)
      )
      (SID_DESC =
         (GLOBAL_DBNAME = TSTDB)
         (SID_NAME = TSTDB)
         (ORACLE_HOME = /u01/app/oracle/product/11.2.0.3/db_1)
      )
  )
2. Put an entry in tnsnames.ora file of both hosts for the two databases
On host PROD:
TEST_TESTDB =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = test)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = testdb)
      (INSTANCE_NAME = testdb)
    )
  )
Subscribe to:
Comments (Atom)
 
