加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

如何强制超时为DriverManager.getConnection()方法调用?

发布时间:2020-12-15 03:00:49 所属栏目:Java 来源:网络整理
导读:我有一个应用程序,它将与 MySQL建立数据库连接并执行查询.有时,DriverManager.getConnection()方法调用需要2秒,有时需要30秒.有没有办法控制此方法2秒后超时? DriverManager.setLoginTimeout()似乎不起作用. 实际上,我可以通过将线程休眠为超时值并在唤醒后
我有一个应用程序,它将与 MySQL建立数据库连接并执行查询.有时,DriverManager.getConnection()方法调用需要2秒,有时需要30秒.有没有办法控制此方法2秒后超时?

DriverManager.setLoginTimeout()似乎不起作用.

实际上,我可以通过将线程休眠为超时值并在唤醒后关闭连接来为statement.executeQuery()设置超时.但它的连接建立部分我无法真正设置超时.

非常感谢任何帮助.

解决方法

如果没有其他选项,您可以始终只在一个单独的线程中执行调用,如果它在2秒内没有完成,您将中止/忽略该线程.

编辑
这是我的想法的一个例子:

public class Dummy extends Thread {
private volatile Connection conn = null;
@Override
public void run() {
    try {
        this.conn = DriverManager.getConnection("foobar") ;
    } catch (SQLException e) {
        e.printStackTrace();
    }
}
static public Connection getConnection() {
    Dummy d = new Dummy() ;
    d.start() ;
    try {
        Thread.sleep(2000) ;
    } catch (InterruptedException e) {}
    return d.conn ;
}
}

然后,您可以在代码中的其他位置调用静态Dummy.getConnection()方法.一个缺点是这种方法总是花费2秒,但是当线程完成时将其更改为立即返回并不太难.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读