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