解决ORACLE数据库连接时出现“ORA-12170:TNS connect timeout occurred”问题的方法如下:
解决ORACLE数据库连接时出现“ORA-12170:TNS connect timeout occurred”问题的方法如下:
问题分析
此问题通常是由于连接超时或者网络故障所引起。解决方法如下:
解决方案
- 确认环境配置
首先需要核实环境的配置是否正确。比如确认防火墙是否阻止了连接,确认listener是否启动,以及确认网络是否正常等。
在Linux系统中,可以使用lsnrctl status
命令来查看监听器启动状态。如果没有启动,请使用lsnrctl start
来启动。如果已经启动了,可以考虑重启listener试试,使用lsnrctl stop
停止监听器,然后使用lsnrctl start
启动监听器。
- 增加超时时间
可以通过在tnsnames.ora文件中增加一个CONNECT_TIMEOUT参数来解决该问题。该参数用于控制连接超时时间的长度。
例如,假设已经添加了以下tns连接:
ORACLE_DB =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
可以在该连接的最后添加CONNECT_TIMEOUT参数:
ORACLE_DB =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
(CONNECT_TIMEOUT = 120)
)
其中,CONNECT_TIMEOUT的值为秒数。
- 使用sqlnet.ora文件
在sqlnet.ora文件中,可以添加以下参数:
SQLNET.INBOUND_CONNECT_TIMEOUT = 120
这将控制才到服务器的连接所需的最长时间(以秒为单位)。请注意,在默认情况下,此参数被禁用。
实例:
sqlnet.inbound_connect_timeout = 120
有了以上的解决方法,就可以顺利解决ORA-12170:TNS connect timeout occurred问题了。
示例说明
1.使用CONNECT_TIMEOUT参数
(1)在tnsnames.ora文件中添加了CONNECT_TIMEOUT参数
ORACLE_DB =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.100)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
(CONNECT_TIMEOUT = 120)
)
如果用户在连接时经常出现ORA-12170错误,则可以尝试将CONNECT_TIMEOUT值增加到更大的值,如240或300。
(2)用户进行连接测试
CMD窗口中连接测试:
C:\Users\Administrator>sqlplus test/test@ORACLE_DB
SQL*Plus: Release 11.2.0.1.0 Production on Fri Aug 23 16:40:04 2019
Copyright (c) 1982, 2010
Oracle. All rights reserved.
ERROR:
ORA-12170: TNS:connect timeout occurred
SP2-0751: Unable to connect to Oracle. Exiting SQL*Plus
从结果来看,虽然仍然存在ORA-12170错误,但是时间已经从连接的默认时间减少到120秒。
- 使用sqlnet.ora文件
(1)修改sqlnet.ora文件
SQLNET.INBOUND_CONNECT_TIMEOUT = 120
(2)进行连接测试
在终端中进行连接测试:
C:\Users\Administrator>sqlplus test/test@ORACLE_DB
SQL*Plus: Release 11.2.0.1.0 Production on Fri Aug 23 16:40:04 2019
Copyright (c) 1982, 2010
Oracle. All rights reserved.
ERROR:
ORA-12170: TNS:connect timeout occurred
SP2-0751: Unable to connect to Oracle. Exiting SQL*Plus
从结果来看,虽然未能解决ORA-12170错误,但sqlnet.ora中设置了SQLNET.INBOUND_CONNECT_TIMEOUT实际上也是增加了连接超时时间。
本文标题为:解决ORA-12170:TNS connect timeout occurred问题
基础教程推荐
- MySQL+Navicat安装配置保姆级教程 2023-07-27
- Kettle连接Oracle数据库方法((Oracle19c&Oracle11g)) 2023-07-23
- pycharm中import导入包呈现灰色的问题及解决 2023-07-28
- SQL Server下7种“数据分页”方案全网最新最全 2023-07-29
- MongoDB卸载安装的详细安装教程 2023-07-16
- MariaDB配置双主复制方案 2023-07-24
- python中如何让输出不换行 2023-07-27
- MySQL中的用户创建与权限管理 2022-10-23
- 实现在线 + 离线模式进行迁移 Redis 数据实战指南 2023-07-12
- MySQL实现按天统计最近七天数据 2022-08-25