yangtingkun
===========================================================
RAC连接的问题ORA-12545(二)
===========================================================

连接到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
已连接。
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
已连接。
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
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。
SQL> CONN NDMAIN/NDMAIN@TESTRAC
已连接。

问题已经解决。不过由于只修改当前客户端的配置,所以这种方法也只对当前客户端有效。

yangtingkun 发表于:2007.04.09 14:17 ::分类: ( ORACLE ) ::阅读:(5493次) :: 评论 (11)
re: RAC连接的问题ORA-12545(二) [回复]

我也遇到了这个问题,多谢。

yuechaotian 评论于: 2007.07.12 09:23
re: RAC连接的问题ORA-12545(二) [回复]

杨大师,我按你的办法做ORA-12545的概率还是很高??
我的client是11.1.0.6.0,RAC是10.2.0.1.0
这个问题是否跟client的版本有关啊?

byfree 评论于: 2008.04.18 15:57
re: RAC连接的问题ORA-12545(二) [回复]

嗯,有可能和版本有关系,我测试的版本也是10.2

yangtingkun 评论于: 2008.04.22 09:48
re: RAC连接的问题ORA-12545(二) [回复]

我觉得这个问题最终应该是域名的解析问题,不管是写HOSTS还是用DNS都存在,因为只要把所有地方写成IP就没这样的问题

byfree 评论于: 2008.04.22 10:41
re: RAC连接的问题ORA-12545(二) [回复]

能否从原理上分析下这个问题的根源?

mulanboy 评论于: 2009.11.25 21:53
re: RAC连接的问题ORA-12545(二) [回复]

导致问题的真正原因不是很清楚,似乎是监听在查找远端监听时碰到了bug

yangtingkun 评论于: 2009.11.26 13:03
re: RAC连接的问题ORA-12545(二) [回复]

不知道这个问题发生的机率有多大啊,我碰到过一次

luckyfriends 评论于: 2010.01.25 10:06
re: RAC连接的问题ORA-12545(二) [回复]

如果存在这个bug,那么出现错误的几率接近5成

yangtingkun 评论于: 2010.01.25 22:36
re: RAC连接的问题ORA-12545(二) [回复]

这个应该不算问题,我抓过IP包,发现返回的包中带的都是主机名而不是IP地址,无论客户端tnsname中是IP还是主机名,RAC返回的都是主机名,所以客户端必须要能解析主机名。

石头狗 评论于: 2010.01.28 12:01
re: RAC连接的问题ORA-12545(二) [回复]

不能要求每个客户端都可以正确的解析服务器端的主机名吧,个人认为RAC在这个问题的处理上还是有一定的问题,在10.2.0.4上就不会出现同样的问题。

yangtingkun 评论于: 2010.01.31 22:54
re: RAC连接的问题ORA-12545(二) [回复]

10.2.0.4上同样有这问题。我遇到过。

amwjd 评论于: 2010.02.05 22:35

发表评论
标题

在此添加评论
表情符号: smile laughing tongue angry crying sad wassat wink

称呼

邮箱地址(可选)

个人主页(可选)

 authimage


切换风格
新闻聚合
博客日历
文章归档...
最新发表...
最新评论...
最多阅读文章...
最多评论文章...
博客统计...
Blog信息
网站链接...