一. 问题一
在做RAC standby 的alert log里发现如下错误: SUCCESS: diskgroup DATA was mountedERROR: failed toestablish dependency between database dave_st and diskgroup resourceora.DATA.dgSUCCESS: diskgroup FRA was mountedERROR: failed toestablish dependency between database dave_st and diskgroup resource ora.FRA.dg 数据库的实例名本来是dave,因为做成RAC standby,所以数据库的db_unique_name 就改成了dave_st。 这个在单实例是没有什么问题,但RAC 的db_unique_name 也会注册到OCR中。 因此对于RAC 的standby,除了要修改数据库的db_unique_name ,还需要修改OCR中,我这里的案例是我原来的RAC 环境已经搭建好的情况,如果是新搭建的环境,就不会出现这种问题了。
二. 问题二
原来的db_unique_name 是dave,后来改成了dave_st。 然后RAC 节点的pfile,就会自动被修改,即使我们修改成dave_st, 在我们使用srvctl start 来启动数据库时,就会自动改成dave,导致不能启动,当然,手工修改之后,在进sqlplus,是可以正常启动,但是用srvctl 检查状态还是未启动。 这也是为什么在RAC 环境下推荐使用srvctl 来启动和关闭数据库,而 不是直接使用sqlplus来操作的原因。 [Oracle@rac2 dbs]$ cat initdave2.oraSPFILE="+DATA/dave/spfiledave.ora" # line added by Agent 这样导致启动时找不到启动文件而报错,如下:[oracle@rac1 dbs]$ srvctl start database -ddavePRCR-1079 : Failed to start resourceora.dave.dbCRS-5017: The resource action"ora.dave.db start" encountered the following error:ORA-01078: failure in processing systemparametersORA-01565: error inidentifying file "+DATA/dave/spfiledave.ora"ORA-17503: ksfdopn:2Failed to open file +DATA/dave/spfiledave.oraORA-15056: additional error messageORA-17503: ksfdopn:2 Failed to open file+DATA/dave/spfiledave.ora
三.解决方法
上面的2个问题,都是因为OCR中数据库的配置出现了问题。 --查看当前配置:[grid@rac1 ~]$ srvctl config database -ddaveDatabase unique name:daveDatabase name: daveOracle home: /u01/app/oracle/11.2.0/db_1Oracle user: oracleSpfile:+DATA/dave/spfiledave.oraDomain:Start options: openStop options: immediateDatabase role: PRIMARYManagement policy: AUTOMATICServer pools: daveDatabase instances:dave1,dave2Disk Groups: DATA,FRAMount point paths:Services:Type: RACDatabase is administrator managed[grid@rac1 ~]$ 我们这里将db_unique_name 修改成dave_st. 不过不能直接修改,需要先将数据库remove掉,在修改。 这里要用oracle用户操作,不然可能会出现权限问题,导致数据库不能启动。 [oracle@rac1 ~]$ srvctl remove database -d dave [oracle@rac1 ~]$ srvctlconfig database -d dave_stDatabase unique name:dave_stDatabase name: daveOracle home: /u01/app/oracle/11.2.0/db_1Oracle user: oracleSpfile:Domain:Start options: openStop options: immediateDatabase role: PRIMARYManagement policy: AUTOMATICServer pools: dave_stDatabase instances: Disk Groups: Mount point paths:Services:Type: RACDatabase is administrator managed[oracle@rac1 ~]$ --修改数据库的其他资源:[oracle@rac1 ~]$ srvctl modify database -d dave_st -a DATA,FRA[oracle@rac1 ~]$ srvctl add instance -d dave_st -i dave1 -n rac1[oracle@rac1 ~]$ srvctl add instance -d dave_st -i dave2 -n rac2[oracle@rac1 ~]$ srvctl modify database -d dave_st -p +DATA/dave_st/spfiledave.ora
最终结果如下:[oracle@rac1 ~]$ srvctl config database -d dave_stDatabase unique name:dave_stDatabase name: daveOracle home: /u01/app/oracle/11.2.0/db_1Oracle user: oracleSpfile:+DATA/dave_st/spfiledave.oraDomain: Start options: openStop options: immediateDatabase role: PRIMARYManagement policy: AUTOMATICServer pools: dave_stDatabase instances:dave1,dave2Disk Groups: DATA,FRAMount point paths:Services:Type: RACDatabase is administrator managed [oracle@rac1 dbs]$ srvctlstatus database -d dave_st Instance dave1 is running on node rac1Instance dave2 is running on node rac2 --验证进程状态:[grid@rac1 u01]$ crs_stat.shName Target State Host------------------------------ ------------------- -------ora.DATA.dg ONLINE ONLINE rac1ora.FRA.dg ONLINE ONLINE rac1ora.LISTENER.lsnr ONLINE ONLINE rac1ora.LISTENER_SCAN1.lsnr ONLINE ONLINE rac1ora.OCRVOTING.dg ONLINE ONLINE rac1ora.asm ONLINE ONLINE rac1ora.cvu OFFLINE OFFLINEora.dave_st.db ONLINE ONLINE rac1 ora.gsd OFFLINE OFFLINEora.net1.network ONLINE ONLINE rac1ora.oc4j OFFLINE OFFLINEora.ons ONLINE ONLINE rac1ora.rac1.ASM1.asm ONLINE ONLINE rac1ora.rac1.LISTENER_RAC1.lsnr ONLINE ONLINE rac1ora.rac1.gsd OFFLINE OFFLINEora.rac1.ons ONLINE ONLINE rac1ora.rac1.vip ONLINE ONLINE rac1ora.rac2.ASM2.asm ONLINE ONLINE rac2ora.rac2.LISTENER_RAC2.lsnr ONLINE ONLINE rac2ora.rac2.gsd OFFLINE OFFLINEora.rac2.ons ONLINE ONLINE rac2ora.rac2.vip ONLINE ONLINE rac2ora.registry.acfs ONLINE ONLINE rac1ora.scan1.vip ONLINE ONLINE rac1[grid@rac1 u01]$ ls 通过以上实验,也可以看出,OCR中的记录是根据DB_UNIQUE_NAME 来进行判断的。而非DB_NAME。
相关阅读:Oracle 11g RAC 执行root.sh时遭遇 CRS-0184/PRCR-1070 http://www.linuxidc.com/Linux/2013-07/87534.htmOracle 11g使用deferred_segment_creation 延迟段创建特性时遇到的问题总结 http://www.linuxidc.com/Linux/2013-07/87293.htmOracle 11g RAC ASM磁盘全部丢失后的恢复 http://www.linuxidc.com/Linux/2013-07/87000.htmOracle 11g新特性:RMAN脚本中使用替换变量 http://www.linuxidc.com/Linux/2013-06/86727.htm更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12Oracle去掉表重复数据Oracle expdp和impdp使用例子相关资讯 Oracle 11g RAC
- Oracle 11g RAC 启动时无法识别ASM (今 15:36)
- Oracle 11g RAC跨实例控制并行 (04月22日)
- Oracle 11g RAC 二节点root.sh执行 (12/27/2015 18:47:25)
| - Oracle 11g RAC 应用补丁简明版 (09月23日)
- Oracle 11g RAC安装注意事项杂记 (12/27/2015 18:49:31)
- Oracle 11g RAC自动打GI PSU补丁( (12/27/2015 18:43:50)
|
本文评论 查看全部评论 (0)