Heim  >  Artikel  >  Datenbank  >  oracle 连接超时问题 ora

oracle 连接超时问题 ora

WBOY
WBOYOriginal
2016-06-07 15:44:431334Durchsuche

场景:服务器双网卡 一个外网访问 一个内网访问 现象:tnsping 服务 通 ping 端口 通 sqlplus 出现ORA-12535: TNS:operation timed out。 解决: init.ora文件的最后加上一条参数: *.dispatchers=(address=(protocol=tcp)(port=5000))(dispatchers=3) 原因

场景:服务器双网卡 一个外网访问 一个内网访问

现象:tnsping  服务 通     ping 端口 通  sqlplus 出现ORA-12535: TNS:operation timed out。 

解决:

init.ora文件的最后加上一条参数:  
    *.dispatchers="(address=(protocol=tcp)(port=5000))(dispatchers=3)"
原因:

需要在MTS模式下(共享模式)Oracle默认是专用模式。  经试验发现,如果不在init文件中设参数的话,Oracle仍然会要求一个随机端口和 1521端口来共同通讯,只是这个随机端口,并不随客户端会话和登录的变化而变化,在 没有重启服务器时,是固定的。 (试验发现,在专用模式下,每次连接,oracle服务器会按+1方式,提供一个非 1521的端口。)    
如果Oracle资料库和client端连线有经过firewall,在MTS模式下连线的设定可能需要特别注意,因为就算你防火墙开通了1521 port,但是在MTS下listener会把连线要求redirect给dispatcher,而dispatcher的port又是random port,这时候你可以选择client端改用Dedicated 连线,或者修改dispatcher设定来达成正常连结,而不会出现ORA-12535: TNS:operation timed out。 

  基本命令:
netstat -an     查看本机通信情况
lsnrctl status 查看监听器情况
ping            查看本地网络
tnsping ***     查看TNS解析
sqlplus         查看客户端应用

# SQL> select name,network from v$dispatcher
  
  NAME NETWORK
  ---- --------------------------------------------------
  D000 (ADDRESS=(PROTOCOL=tcp)(HOST=ora1)(PORT=5000))
  D001 (address=(protocol=tcp)(port=5000))
  D002 (address=(protocol=tcp)(port=5000))


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn