您好,欢迎访问一九零五行业门户网

oracle 连接超时问题 ora

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

推荐信息