您的位置:

ORA-03135:详解Oracle数据库连接超时异常

一、背景

在使用Oracle数据库过程中,我们可能会遇到ORA-03135异常,该异常通常被描述为数据库连接超时异常。此时,客户端和数据库通信连接失去联系。在以下情况中,可能会遇到ORA-03135:

1、在连接数据库时,网络传输错误,网络中断或数据库主机关闭了正在运行的实例;

2、用户执行数据库操作时,连接超时,未能在指定的时间内完成操作;

3、客户端与Oracle数据库的连接配置错误;

4、或是出现了其他未知的异常或故障。

二、常见错误信息

当ORA-03135异常发生时,我们通常会看到以下错误提示:

ORA-03135: 连接丢失联系

或者在客户端的日志中,也会出现:

All connections to the server have been lost.

这些错误提示告诉我们,客户端和数据库通信连接已经断开了,客户端已无法与数据库进行通信。我们需要详细了解该异常,以便能够更有效地进行调试和解决问题。

三、异常原因分析

ORA-03135异常通常是由以下原因导致的:

1、数据库服务器宕机,网络中断,或服务器运行实例被关闭,这些都可能导致客户端无法与数据库建立连接或无法正常通信;

2、客户端与数据库间设置的传输保持存活超时值设置不正确,造成连接超时;

3、客户端和数据库之间的网络延迟过高,导致传输数据失败;

4、连接池中的连接被关闭,造成无法连接到数据库;

5、数据库服务器cpu占用较高,导致网络传输数据的效率下降,从而造成ORA-03135异常。

四、异常解决方案

针对不同的异常原因,我们可以采取不同的解决方案来解决ORA-03135异常:

1、检查数据库连接

不断地检查数据库连接是否可用,保证网络畅通。

String url = "jdbc:oracle:thin:@localhost:1521/orcl";
String username = "system";
String password = "system";
Connection conn = null;

try {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    conn = DriverManager.getConnection(url, username, password);
    if (conn != null){
        System.out.println("Connection successfull!");
    }
} catch (SQLException e) {
    e.printStackTrace();
} catch (ClassNotFoundException e) {
    e.printStackTrace();
} finally {
    if (conn != null)
        conn.close();
}

2、设置SQLNET文件

在oracle数据库中的sqlnet.ora文件中,添加下面的属性,重新启动tnslistener服务,重新连接即可。

SQLNET.EXPIRE_TIME = 10
SQLNET.INBOUND_CONNECT_TIMEOUT = 600

3、使用连接池

使用连接池技术,进行数据库连接的管理和连接池的维护。

DataSource ds = new OracleDataSource();
ds.setDriverType("thin");
ds.setServerName("localhost");
ds.setPortNumber(1521);
ds.setDatabaseName("orcl"); 
ds.setUser("system"); 
ds.setPassword("system"); 
Connection conn = ds.getConnection();

4、调整超时时间

在数据库连接程序中,设置合理的超时时间。可以通过修改sqlnet.ora文件、修改连接池参数、添加try-catch包含捕获异常等方式达到设置超时时间的目的。

public void setConnectionProperties(String user, String password, String url) {
     Properties props = new Properties();
     props.setProperty("user", user);
     props.setProperty("password", password);
     props.setProperty("autoReconnect", "true");
     props.setProperty("connectTimeout", "5000");
     props.setProperty("socketTimeout", "25000");

     this.url = url;
     this.connectionProperties = props;
     connect();
}

5、检查人员工作

如果ORA-03135异常是由人为错误造成,那么就需要检查人员工作。比如数据库管理员是否将数据库实例关闭,或者网络运维管理员是否设置了网络隔离规则...

五、总结

本文详细介绍了ORA-03135异常的常见出现原因,以及针对不同类型异常的解决方案。我们希望读者能够了解到该异常的产生原因及解决方法,能够快速定位并解决该异常,保证数据库系统的安全性和稳定性。