oracle10g RAC ora-12545因目标主机或对象不存在的错误解决

由于历史原因,应用升级需要成本,最近新上了一套oracle 10g RAC (10.2.0.5),测试时,从其他应用服务器,链接这套数据库,使用的是vip链接,发现大量报错,报错为ora-12545因目标主机或对象不存在。
ORA-12545: Connect failed because target host or object does not exist


查询网上资料和mos文档,

导致这个问题的原因
Whe LOCAL_LISTENER is not set at all or is not set correctly, PMON can register both the VIP hostname and the physical hostname with the REMOTE_LISTENER.  This is incorrect in RAC but if it does occur, the client can intermittently be routed to a listener endpoint on either of these addresses.  If the client is unable to resolve the physical hostname or even the vip hostname, the connection will fail with ORA-12545.

由于 LOCAL_LISTENER未配置或者配置不争取,PMON进程使用的是REMOTE_LISTENER注册vip hostname和物理地址,在rac里面,这是不对的配置,客户端无法使用这些地址正确路由到监听服务器。如果客户端无法正确解析物理地址或者vip的hostname,链接就会报  ORA-12545错误。


Additionall, if the VIP hostname cannot be resolved, but the VIP numerical address is reachable; then this VIP numerical address should be used as the HOST value for LOCAL_LISTENER instead.


And important first set is to check the output for :  lsnrctl services


You should not see the physical hostname in the handler information for your RAC instances.   Here's an example of an incorrect lsnrctl services output for a 2-node RAC cluster:


lsnrctl services oracle_rac_listener 
Service "oracle.oracle.com" has 2 instance(s). 
Instance "orcl1", status READY, has 2 handler(s) for this service... 
Handler(s): 
"DEDICATED" established:0 refused:0 state:ready 
REMOTE SERVER 
(ADDRESS=(PROTOCOL=TCP)(HOST=myphysicalhost1)(PORT=1521)) 
"DEDICATED" established:326 refused:0 state:ready 
LOCAL SERVER 


Instance "orcl2", status READY, has 1 handler(s) for this service... 
Handler(s): 
"DEDICATED" established:394371 refused:0 state:ready 
REMOTE SERVER 
(ADDRESS=(PROTOCOL=TCP)(HOST=myphysicalhost2)(PORT=1521))
 


Here's an example of what it ought to look like when LOCAL_LISTENER is configured correctly:


lsnrctl services oracle_rac_listener 
Service "oracle.oracle.com" has 2 instance(s). 
Instance "orcl1", status READY, has 2 handler(s) for this service... 
Handler(s): 
"DEDICATED" established:0 refused:0 state:ready 
REMOTE SERVER 
(ADDRESS=(PROTOCOL=TCP)(HOST=myVIP_host1)(PORT=1521)) 
"DEDICATED" established:326 refused:0 state:ready 
LOCAL SERVER 


Instance "orcl2", status READY, has 1 handler(s) for this service... 
Handler(s): 
"DEDICATED" established:394371 refused:0 state:ready 
REMOTE SERVER 
(ADDRESS=(PROTOCOL=TCP)(HOST=myVIP_host2)(PORT=1521))


解决方案:

分别修改两边的RAC实例的 LOCAL_LISTENER配置。
alter system set LOCAL_LISTENER="(address=(protocol=tcp)(port=1521)(host=))" scope=both sid='INSTANCE_NAME1';
alter system set LOCAL_LISTENER="(address=(protocol=tcp)(port=1521)(host=))" scope=both sid='INSTANCE_NAME2'; 


另外,相关配置 REMOTE_LISTENER.
alter system set  REMOTE_LISTENER='' scope=both sid='*';

另外parallel_instance_group参数也可以配置不一样的值

alter system set parallel_instance_group="A" scope=both sid='INSTANCE_NAME1';
alter system set parallel_instance_group="B" scope=both sid='INSTANCE_NAME2'; 

最后,注意的是,修改完后,重启监听,如果重启监听都不行,重启一下数据库或者两个实例重启一下。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31429550/viewspace-2149277/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31429550/viewspace-2149277/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值