Oracle 10g RAC连接错误ORA-12545

在远端客户端连接RAC数据库时,通过统一的服务名连接时经常会出现ORA-12545错误。

Sql代码
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******
ERROR:ORA-12545: 因目标主机或对象不存在, 连接失败警告: 您不再连接到 ORACLE。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******
ERROR:ORA-12545: 因目标主机或对象不存在, 连接失败警告: 您不再连接到 ORACLE。

本地数据库TNSNAMES的配置:

Tnsnames代码
nuagerac =
(DESCRIPTION =
 (ADDRESS = (PROTOCOL = TCP)(HOST =192.168.1.127)(PORT= 1521))
 (ADDRESS = (PROTOCOL = TCP)(HOST =192.168.1.128)(PORT = 1521))
 (LOAD_BALANCE = yes)
 (CONNECT_DATA =
  (SERVER = DEDICATED)
  (SERVICE_NAME = nuagerac)
  (FAILOVER_MODE =
   (TYPE = SELECT)
   (METHOD = BASIC)
   (RETRIES = 180)
   (DELAY = 5)
  )
 )
)

Oracle在文档Note:364855.1:RAC Connection Redirected To Wrong Host/IP ORA-12545中进行了相应的描述。并给出了解决方法:
修改数据库中的初始化参数LOCAL_LISTENER:
 
Sql代码
SQL> CONN SYS@nuage1 AS SYSDBA输入口令: ****已连接。

SQL> ALTER SYSTEM SET LOCAL_LISTENER = '(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.127)(PORT = 1521))' SID = 'nuage1';系统已更改。

SQL> CONN SYS@nuage2 AS SYSDBA输入口令: ****已连接。

SQL> ALTER SYSTEM SET LOCAL_LISTENER = '(ADDRESS = (PROTOCOL =TCP)(HOST = 192.168.1.128)(PORT = 1521))' SID = 'nuage2';系统已更改。
设置之后,再次尝试连接数据库:
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。
SQL> CONN NDMAIN@nuagerac输入口令: ******已连接。

修改之后,到目前为止再也没有出现ORA-12545的错误信息
不过Oracle没有认为这个是bug,只是认为是PROBLEM。

  1. da shang
    donate-alipay
               donate-weixin weixinpay

发表评论↓↓