li
  当前位置:主页 > 备份恢复 > 文章内容
li
RAC连接的问题ORA-12545(二)
来源: http://yangtingkun.itpub.net/  作者: yangtingkun    时间:2008-01-26   阅读:23  
本文章共1733字,分2页,当前第1页,快速翻页:
 

连接到RAC数据库的时候经常会出现ORA-12545错误,在METALINK上查询了一下,是Oracle的一个小bug

RAC连接的问题ORA-12545http://yangtingkun.itpub.net/post/468/273645


上一篇文档已经给出这个问题的解决方法了,不过今天发现另外一个解决方案。

文档一中给出的解决方法可以彻底的解决这个问题,而且对所有的连接都是有效的。不过缺点也是很明显的。需要修改初始化参数,重启实例,重启监听。有的时候,这个操作的代价太大了。这篇文章介绍的方法可以通过只修改客户端hosts文件的方式,来解决这个问题。

客户端的tnsnames.ora中的配置如下:

SQL> host
$ more $ORACLE_HOME/network/admin/tnsnames.ora
# tnsnames.ora Network Configuration File: /data/oracle/product/10.2/database/network/admin/tnsnames.ora
# Generated by Oracle configuration tools.

LISTENER_TESTRAC2 =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.225)(PORT = 1521))


LISTENER_TESTRAC1 =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.224)(PORT = 1521))


TESTRAC =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.224)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.225)(PORT = 1521))
(LOAD_BALANCE = yes)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = testrac)
(FAILOVER_MODE =
(TYPE = SELECT)
(METHOD = BASIC)
(RETRIES = 180)
(DELAY = 5)
)
)
)

TESTRAC2 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.225)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = testrac)
(INSTANCE_NAME = testrac2)
)
)

TESTRAC1 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.224)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = testrac)
(INSTANCE_NAME = testrac1)
)
)

LISTENERS_TESTRAC =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.224)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.25.198.225)(PORT = 1521))
)

下面尝试连接远端RAC数据库:

$ exit

SQL> CONN NDMAIN/NDMAIN@TESTRAC已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。

www.ixdba.net


SQL> CONN NDMAIN/NDMAIN@TESTRAC
ERROR:
ORA-12545:
因目标主机或对象不存在, 连接失败

警告: 您不再连接到 ORACLE
SQL> CONN NDMAIN/NDMAIN@TESTRAC
ERROR:
ORA-12545:
因目标主机或对象不存在, 连接失败


SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
ERROR:
ORA-12545:
因目标主机或对象不存在, 连接失败

警告: 您不再连接到 ORACLE
SQL> CONN NDMAIN/NDMAIN@TESTRAC
ERROR:
ORA-12545:
因目标主机或对象不存在, 连接失败

可以看到,连接失败的概率还是很高的。其实只有在本地hosts文件中加上RAC实例所在服务器的ip和主机名信息,就可以避免这个错误:

SQL> host
$ su -
Password:
Sun Microsystems Inc. SunOS 5.10 Generic January 2005
Sourcing //.profile-EIS.....
root@ahrac1 # vi /etc/hosts
#
# Internet host table
#
172.25.198.224 racnode1-vip
172.25.198.225 racnode2-vip

root@ahrac1 # exit
$ exit

SQL>

下面再次尝试连接RAC数据库:

SQL> CONN NDMAIN/NDMAIN@TESTRAC已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。



阅读更多内容1 · 2 · 下一页>>


  上一篇: Oracle srvctl的小bug   下一篇: RAC User Equivalence Check Fai...
li
 §相关评论  
 热点文章

·Oracle数据库远程复制与异地容
·Oracle 11g备份恢复功能增强
·UNDO表空间的ORA-1122错误解决
·UNDO表空间的ORA-1122错误解决
·UNDO表空间的ORA-1122错误解决
·使用Flashback Query 恢复误删
·如何开启/关闭oracle的归档
·Rman的format格式中的%s类似的
·怎么样创建RMAN恢复目录
·ORA-01843:无效的月份,这个是
·ORA-01843:无效的月份
li
 编辑推荐
·Oracle数据库远程复制与异地容
·Oracle 11g备份恢复功能增强
·UNDO表空间的ORA-1122错误解决
·UNDO表空间的ORA-1122错误解决
·UNDO表空间的ORA-1122错误解决
·使用Flashback Query 恢复误删
·如何开启/关闭oracle的归档
·Rman的format格式中的%s类似的
·怎么样创建RMAN恢复目录
·ORA-01843:无效的月份,这个是
·ORA-01843:无效的月份
li
 相关篇章
·Oracle srvctl的小bug
·ORA-17447错误
·一次ASM环境故障解决
·Solaris10下安装Oracle10203RAC环...
·Solaris10下安装Oracle10203RAC环...
·Solaris10下安装Oracle10203RAC环...
·Solaris10下安装Oracle10203RAC环...
·RAC负载均衡的简单测试(一)
·RAC负载均衡的简单测试(三)
·RAC负载均衡的简单测试(二)
·RAC User Equivalence Check Fai...
·RAC连接的问题ORA-12545
·Solaris8上安装RAC10202环境(六...
·Solaris8上安装RAC10202环境(四...
·Solaris8上安装RAC10202环境(三...
·Solaris8上安装RAC10202环境(五...
·Solaris8上安装RAC10202环境(二...
·Oracle 10gr2 Bug 4437727
·Solaris8上安装RAC10202环境(一...
·DBCA建库报错ORA-119
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接