ホームページ  >  記事  >  データベース  >  oracle 连接超时问题 ora

oracle 连接超时问题 ora

WBOY
WBOYオリジナル
2016-06-07 15:44:431334ブラウズ

场景:服务器双网卡 一个外网访问 一个内网访问 现象: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))


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。