当前位置:Gxlcms > mysql > oracle连接超时问题ora

oracle连接超时问题ora

时间:2021-07-01 10:21:17 帮助过:51人阅读

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

人气教程排行