这篇文章中将要建立前两篇文章中的实例数据库Practice的一个克隆数据库,我们将之命名为CLNE,我们这里的原数据与克隆的数据库兹同一台机器上,因此无需再进行Oracle安装,但一般情况下需要首先在克隆目标机器上安装Oracle软件,而且要与原数据库的Oracle具有相同的版本,具体步骤如下:

1、准备CLNE数据库

  ①、为CLNE数据库创建所需的路径,执行如下命令:

   export ORACLE_SID=CLNE;

   export ORACLE_BASE=/app/oracle;

   export ORACLE_HOME=/app/oracle/;

   export ORACLE_DATA=/oracledata/$ORACLE_SID;

  export ORACLE_ADMIN=$ORACLE_BASE/admin/$ORACLE_SID;

   mkdir $ORACLE_ADMIN;

   mkdir $ORACLE_ADMIN/pfile;

   mkdir $ORACLE_ADMIN/bdump;

   mkdir $ORACLE_ADMIN/cdump;

   mkdir $ORACLE_ADMIN/udump;

   mkdir $ORACLE_ADMIN/create;

   mkdir $ORACLE_DATA;

   mkdir $ORACLE_DATA/archive;

  ②、准备参数文件和口令文件:

   如果在Linux上可以使用如下命令:

   cp $ORACLE_BASE/admin/PRACTICE/pfile/initPRACTICE.ora

     $ORACLE_BASE/admin/CLNE/pfile/initCLNE.ora;

   ln –s $ORACLE_BASE/admin/CLNE/pfile/initCLNE.ora

       $ORACLE_HOME/dbs/initCLNE.ora;

以上两条命令将PRACTICE数据库的默认参数文件拷贝了一份到CLNE数据库相应路径之下,作为CLNE数据库的默认参数文件,并且建立了CLNE数据库的默认参数文件到默认数据库参数文件的一个软连接。

如果是Windows系统,因为无法建立软连接,可以把PRACTICE数据库的默认参数文件,拷贝到CLNE相应位置,并在默认数据库创建一个新文件并包含IFILE关键字,所以可适用如下命令:

copy $ORACLE_BASE/admin/PRACTICE/pfile/initPRACTICE.ora

$ORACLE_BASE/admin/CLNE/pfile/initCLNE.ora;

notepad $ORACLE_HOME/dbs/initCLNE.ora > IFILE=d:/app/oracle/admin/CLNE/pfile/initCLNE.ora;

复制完参数文件之后,需要对CLNE数据库中的默认参数文件,即pfile下的initCLNE.ora进行修改,主要是将原来的有关PRACTICE的内容替换成CLNE,主要替换的内容如下,可能还会包含其它一些内容,视情况而定:

 db_name=CLNE

 instance_name=CLNE

 log_archive_dest_1=”location=/oradata/CLNE/archive”

 background_dump_dest=/app/oracle/admin/CLNE/bdump

 core_dump_dest=/app/oracle/admin/CLNE/udump

 control_files=(“/oradata/CLNE/control01.ctl”,

” /oradata/CLNE/control02.ctl”,” /oradata/CLNE/control03.ctl”)

本例中将在同一块磁盘的相同位置创建三个控制文件,但通常会在不同的存储位置创建控制文件,以便有效保护控制文件。

接下来要创建口令文件,以便在SQL*PLUS中以SYSDBA角色登陆数据库,以及进行远程管理。

orapwd file=$ORACLE_HOME/dbs/orapwCLNE password=CLNE entries=4;

如果在Windows系统中还需要为CLNE数据库创建一个服务,该服务将会命名为OracleServiceCLNE,使用如下命令:

oradim –new –sid CLNE intpwd CLNE;

2、  备份打开的PRACTICE数据库:

使用上一篇文章中的热备份脚本open_backup.sql,并做出如下修改,将dir用户变量值修改为/oradata/CLNE,并删除原先用于创建控制文件复制的命令行,因为当复制数据库时将会使用新的数据库名称,创建一个新的控制文件。修改完毕之后,以sys用户登录系统,并执行备份脚本,如果执行成功,将会在/oradate/CLNE文件夹下得到一个PRACTICE数据库的非一致性副本。

3、  配置控制文件脚本:

可是使用create controlfile命令对备份数据库创建一个新的专用配置文件。但是这个命令相当繁琐,如果适用这个命令那么将会需要一定工作量。但是我们有一条捷径可以采用,我们可以通过如下指令:

alter database backup controlfile to trace resetlogs;

通过这条指令,Oracle服务器会自动产生一个包含创建控制文件全部命令的脚本文件。该文件将会存放于user_dump_dest初始化参数所指定的文件中。可以使用如下查询来查找该参数所对应的文件目录:

select value from v$parameter where name=’user_dump_dest’;

   在这个文件目录下,按生成的时间日期值寻找到该文件,并经该文件拷贝到$ORACLE_BASE/admin/CLNE/create目录下,并重命名为create_control_file.sql。然后对该文件进行如下修改:

①删除脚本中的注释行以及所有以#号开头的行。

②将create controlfile命令中的reuse关键字替换成set关键字,代表重新创建一个备用数据库适用的全新控制文件,并且改变数据库名称,而删除原数据库名称。

③将create controlfile命令中的所有PRACTICE替换成CLNE。所创建的控制文件被用于名为CLNE的数据库。

④将每个数据文件和重做日志文件的路径由/oradate/PRACTICE改为/oradata/CLNE。

最后修改后的文件片断类似如下所示:

 startup nomount

 create controlfile set database “CLNE” resetlogs archivelog

maxlogfiles 16

maxlogmembers 2

maxdatafiles 30

maxinstances 1

maxloghistory 226

 logfile

group 1 ‘/oradata/CLNE/redo03.log’ size 1M,

group 1 ‘/oradata/CLNE/redo02.log’ size 1M,

group 1 ‘/oradata/CLNE/redo01.log’ size 1M

datafile

‘/oradata/CLNE/system01.dbf’,

‘/oradata/CLNE/tools01.dbf’,

‘/oradata/CLNE/rbs01.dbf’,

‘/oradata/CLNE/temp01.dbf’,

‘/oradata/CLNE/users01.dbf’,

‘/oradata/CLNE/index01.dbf’,

‘/oradata/CLNE/users02.dbf’

Character set webiso8859-1;

4、  运行控制文件脚本:

export ORACLE_SID=CLNE

cd  /ORACLE_BASE/admin/$ORACLE_SID/create

sqlplus nolog

connect sys/CLNE as sysdba;

@create_control_file.sql;

注意这个脚本可以在任何一台使用NET8 sql*plus的客户端机器运行。

5、  恢复克隆数据库:

要对打开的各个从PRACTICE复制而来的数据文件进行恢复,因为这些文件是在PRACTICE数据库处于待开状态下进行备份的,当数据库的表空间处于备份模式时,数据文件的检查点SCN是不同的。因此每个数据文件都必须使用来自PRACTICE数据库的归档日志文件来进行恢复。如果使用的备份文件,是PRACTICE数据库在关闭状态下的备份产物,那么将不需要恢复,一位在关闭时数据库会自动同步数据文件,控制文件以及联机重做日志文件的SCN号,使数据库处于一致状态,所以不需要进行恢复。使用如下命令进行恢复:

set  logsource  /oradata/backup/archive;通过该指令指示CLNE数据库在恢复时,要在PRACTICE数据库的归档日志文件目录下寻找恢复使用的归档日志。

recover database using backup controlfile until cancel;通过该命令采用基于取消的恢复,实施恢复直道用完了所有需要使用的归档日志。当来自PRACTICE数据库的所有归档日志,全部被应用后,又如下两个选择:

(1)                在PRACTICE数据库上强制日志切换,并将新归档的日志应用于CLNE数据库。这样PRACTICE数据库在日志切换前的所有改变都会应用到CLNE数据库上。之后可以在CLNE数据库恢复提示中键入cancel这样就可以打开CLNE数据库了。

(2)                关闭PRACTICE数据库,然后在CLNE数据库恢复提示中键入/oradata/PRACTICE/redo01.log(假设redo01.log为当前联机重做日志文件),这样将会把PRACTICE数据库的当前联机重做日志文件应用到CLNE数据库上。一位数据库是不断在写入联机重做日志文件的,所以不要在PRACTICE数据库打开时应用当前联机重做日志到CLNE数据库上。此时如果恢复完成将会看到,media recover complete。

6、  打开克隆数据库:

当看到介质恢复成功的提示后,就可以使用resetlogs选项打开数据库了。

alter database open resetlogs;