解决ORA-12170:TNS connect timeout occurred问题

2023-12-07数据库
1214

解决ORACLE数据库连接时出现“ORA-12170:TNS connect timeout occurred”问题的方法如下:

问题分析

此问题通常是由于连接超时或者网络故障所引起。解决方法如下:

解决方案

  1. 确认环境配置

首先需要核实环境的配置是否正确。比如确认防火墙是否阻止了连接,确认listener是否启动,以及确认网络是否正常等。

在Linux系统中,可以使用lsnrctl status命令来查看监听器启动状态。如果没有启动,请使用lsnrctl start来启动。如果已经启动了,可以考虑重启listener试试,使用lsnrctl stop停止监听器,然后使用lsnrctl start启动监听器。

  1. 增加超时时间

可以通过在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的值为秒数。

  1. 使用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秒。

  1. 使用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实际上也是增加了连接超时时间。

The End

相关推荐

liunx mysql root账户提示:Your password has expired. To log in yo
liunx mysql root账户提示:Your password has expired. To log in you must change it using a client that supports expired passwords,要怎么操作呢? 1、修改 /etc/my.cnf,在 [mysqld] 小节下添加一行:skip-grant-tables=1 这一行配置让 mysqld 启动...
2024-12-24 数据库
149

快速解决PostgreSQL中的Permission denied问题
下面是针对PostgreSQL中的权限问题的完整攻略。...
2023-12-07 数据库
3413

MySQL时间类型和模式详情
MySQL是一种流行的关系型数据库系统,它提供了多种时间类型和模式,用于存储和处理时间数据。本文将详细介绍MySQL时间类型和模式的详细攻略。...
2023-12-07 数据库
15

VMware中安装CentOS7(设置静态IP地址)并通过docker容器安装mySql数据库(超详细教程)
首先在官网下载CentOS7镜像,并在VMware虚拟机中新建一台CentOS7虚拟机,将镜像挂载到虚拟机中并启动。...
2023-12-07 数据库
11

SpringBoot项目报错:”Error starting ApplicationContext̷
首先,当我们使用Spring Boot开发项目时,可能会遇到Error starting ApplicationContext错误,一般这种错误是由于配置文件、依赖包或者代码逻辑等原因引起的。下面我将提供一条包含两条详细示例说明的完整攻略,用来解决上述问题。...
2023-12-07 数据库
489

Postgresql 赋予用户权限和撤销权限的实例
下面我将详细讲解如何为PostgreSQL数据库中的用户授予权限和撤销权限,包括两个实例。...
2023-12-07 数据库
30