RAC连接的问题ORA-12545
来源:互联网 发布:40部网络禁书 编辑:程序博客网 时间:2024/05/11 14:12
连接到RAC数据库的时候经常会出现ORA-12545错误,在METALINK上查询了一下,是Oracle的一个小bug。
RAC连接的问题ORA-12545:http://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已连接。
问题已经解决。不过由于只修改当前客户端的配置,所以这种方法也只对当前客户端有效。
- RAC连接的问题ORA-12545
- RAC连接的问题ORA-12545
- RAC连接的问题ORA-12545
- RAC连接的问题ORA-12545
- Oracle 集群RAC拒绝连接问题ORA-12545解决
- oracle10g的rac中,客户端连接报ora-12545错误
- 连接Oracle RAC 的tnsname.ora设置
- oracle11gR2 RAC连接时ORA-12545错误
- XDB引起的RAC问题 ORA-03113
- ORA-12545:连接失败的问题
- 连接到RAC数据库的时候经常会出现ORA-12545错误
- RAC 集群 连接的时候报错 ora-12541
- oracle 10G r2 RAC连接ORA-12545错误
- Oracle10g Rac ora-12545
- Oracle10g Rac ora-12545
- 关于ORACLE连接RAC不稳定的问题
- Oracle 11g RAC环境下的ORA - 19606问题
- ORA RAC ORA-12545:因目标主机或对象不存在,连接失败!
- 【数据结构与算法】——排序算法篇
- 2013年9月华为成都笔试题 输入字符串计算数值(c语言)
- 向导制作组件使用说明
- SPL讲解(6)--Condition篇
- 开发cocos2d-x 游戏 实战篇(8)--终结篇
- RAC连接的问题ORA-12545
- ADB server didn't ACK * failed to start daemon * 解决方法
- window.navigate 与 window.location.href 的使用区别
- ssh jar包配置
- SPL讲解(5)---事务处理篇
- Myeclipse远程debug配置
- 今天开始写技术博客!
- android 九宫格轨迹密码
- 关于重写