During the interviews this is always asked, like "Tell me how do you do the Cloning in R12?"
We all know what happens in Cloning, but now we shall also know how is it done internally.
So I thought I shall dig up some information about how oracle works, whats the idea behind.
Starting with the few basic statements that we might have heard alot. I will put them in a question/answer pattern.
In this post I am focusing only on the Database part.
Q: Why do we need
to do cloning?
-> To test some
application by patching or coding which can affect the whole application or may
need downtime for the process to be carried out. So, in order to avoid the loss
in business due to these mentioned factors, we need to clone the Oracle Application.
Q. What are the
different cloning methods supported by Oracle?
-> There can be many cloning
methods but oracle supports only 1, i.e., RAPID CLONE.
On the basis of Config. We can divide them as
1. With AUTOCONFIG. (Completely replaced by Rapid Clone now.)
2. Without AUTOCONFIG. (used before 11.5.5)
On the basis of Config. We can divide them as
1. With AUTOCONFIG. (Completely replaced by Rapid Clone now.)
2. Without AUTOCONFIG. (used before 11.5.5)
Q. What is the need to run adpreclone?
-> This will create
the staged clone directory which will be having the driver files and
configuration file (XML File) of the source.
Q: How does adpreclone.pl
dbTier will run
-> After runnning this, it will go in two
stages
1. dbTechStack 2. Database
1. dbTechStack 2. Database
Q: Explain dbTechStack and
Database in details:
-> It will create
stage cloned area at $ORACLE_HOME/appsutil/clone This clone directory has got
following main directories
data,jre,bin,db,html,context
This will prepare the database techstack at dbTechStack stage.
data,jre,bin,db,html,context
This will prepare the database techstack at dbTechStack stage.
1. Creates
template files at $ORACLE_HOME/appsutil/template
2. Creates driver files at $ORACLE_HOME/appsutil/driver/instconf.drv
3. Converts inventory from binary to xml
2. Creates driver files at $ORACLE_HOME/appsutil/driver/instconf.drv
3. Converts inventory from binary to xml
Now
the database stage:
It
will prepare database at the database stage. Major activities includes
1. Create database control file script
$ORACLE_HOME/appsutil/clone/context/data/stage/addbhomsrc.xml
$ORACLE_HOME/appsutil/clone/context/data/stage/adcrdb.zip
adcrdbclone.sql
$ORACLE_HOME/appsutil/clone/context/data/stage/adcrdb.zip
adcrdbclone.sql
2. Generates
database creation driver file
$ORACLE_HOME/appsutil/clone/context/data/driver/data.drv
$ORACLE_HOME/appsutil/clone/context/data/driver/data.drv
3. Copy
JDBC Libraries
$ORACLE_HOME/appsutil/clone /clone/jlib/classes111.zip
$ORACLE_HOME/appsutil/clone /clone/jlib/classes111.zip
________________________________________
NOW adcfgclone.pl dbTier (On TARGET NODE)
This will also run in two
modes
1. dbTechStack stage:
It will make use template and driver files which were created during preclone
process. And it will run the following scripts
adchkutl.sh
adclonectx.sh
runInstallConfigDriver - located in $ORACLE_HOME/appsutil/driver/instconf.drv
Relinking of ORACLE_HOME/appsutil/install/adlnkoh.sh
adchkutl.sh
adclonectx.sh
runInstallConfigDriver - located in $ORACLE_HOME/appsutil/driver/instconf.drv
Relinking of ORACLE_HOME/appsutil/install/adlnkoh.sh
2. Now for the Database Stage
Driver File $ORACLE_HOME/appsutil/clone/context/data/driver/data.drv
Create Database using adcrdb.zip file
Autoconfig is Run
Controlfile is created using adcrdbclone.sql
Create Database using adcrdb.zip file
Autoconfig is Run
Controlfile is created using adcrdbclone.sql
3. Generates database creation driver file
$ORACLE_HOME/appsutil/clone/context/data/driver/data.drv
4. Copy JDBC Libraries
$ORACLE_HOME/appsutil/clone /clone/jlib/classes111.zip
Ok, Now you can sleep and dream about the cloning.
----------- That's it ------