克隆一个已经存在的Oracle Home,免掉新安装oracle10g软件的痛苦,如果原Oracle Home已经安装了patch就省得打patch了。一、在目标
克隆一个已经存在的Oracle Home,免掉新安装oracle10g软件的痛苦,如果原Oracle Home已经安装了patch就省得打patch了。
一、在目标主机172.19.111.37上做安装前准备工作
1、增加组和用户(和克隆主机的目录结构一样)
# groupadd oinstall
# groupadd dba
# userdel oracle10
# useradd -g oinstall -G dba -d /opt/oracle/oracle10 -m -s /bin/ksh oracle10
# passwd -r files oracle10
2、建立需要的目录
# mkdir /opt/oracle/oradata/oracle10_data (存放将来建库的数据文件)
# chown oracle10:oinstall /opt/oracle/oradata/oracle10_data
# chmod 755 /opt/oracle/oradata/oracle10_data
# mkdir /opt/oracle/oradata/flash_recovery_area (存放将来建库的闪回文件)
# chown oracle10:oinstall /opt/oracle/oradata/flash_recovery_area
# chmod 755 /opt/oracle/oradata/flash_recovery_area
3、修改oratab文件权限
# more /var/opt/oracle/oratab
# chown oracle10:oinstall /var/opt/oracle/oratab
# chmod 755 /var/opt/oracle/oratab
4、停止已有的oracle监听进程。
# su - oracle
$ lsnrctl stop
$ sqlplus '/as sysdba'
SQL> shutdown immediate
二、停止和克隆主机172.19.111.38上ORACLE_HOME相关的所有进程
$ emctl stop dbconsole (停Database Control)
$ lsnrctl stop (停Net Listener)
$ isqlplusctl stop (停iSQL*PLUS)
$ searchctl stop (停Ultra Search)
三、对克隆主机ORACLE_HOME目录下内容打zip包
$ cd $ORACLE_HOME/../
$ zip -r db_1.zip /opt/oracle/oracle10/app/product/10.2.0/Db_1
注意,,不要把admin、flash_recovery_area、oradata目录打包,这些克隆后重新生成
四、拷贝zip包和.profile文件到目标主机
$ ftp 172.19.111.37
ftp> user oracle10 oracle10
上传db_1.zip和.profile
五、进入目标主机解压zip包
$ . .profile
$ unzip -d / db_1.zip
六、进入解压后的ORACLE_HOME目录,删除所有的$ORACLE_HOME/network/admin/*.ora文件
$ cd $ORACLE_HOME/network/admin
$ rm *.ora
七、以clone模式启动OUI(无需XBrower登陆),ORACLE_HOME_NAME要唯一
$ $ORACLE_HOME/oui/bin/runInstaller -silent -clone ORACLE_HOME="/opt/oracle/oracle10/app/product/10.2.0/Db_1" ORACLE_HOME_NAME="db_1"
八、新建数据库(得用XBrower登陆)
$ cd $ORACLE_HOME/bin
$ ./dbca
九、网络配置助手(得用XBrower登陆)
$ cd $ORACLE_HOME/bin
$ ./netca
分别做Listener configuration和Local net service name configuration(假设配置为orcl10)
十、测试
$ ps -ef | grep ora_ (检查oracle10g是否启动)
$ lsnrctl status (检查监听是否启动)
$ tnsping orcl10 (检查配置的网络服务名是否正确)
$ emctl start dbconsole (启动database console)
$ isqlplusctl start (启动isqlplus)
进入 :5500/em/ 查看数据库状态信息