现在的位置: 首页 > 综合 > 正文

关于解决数据库网络断开重新连接的尝试

2018年04月06日 ⁄ 综合 ⁄ 共 611字 ⁄ 字号 评论关闭

最近遇到一个比较恶心的问题。有一个项目,在启动的时候,需要先启动数据库,再启动tomcat,这样子程序才可以连接上。然而,tomcat和数据库是分开在两台不同的服务器上,而且管理这个服务器的人定死了了一套约定,一定是先打开tomcat所在的服务器,在打开数据库所在的服务器,导致了程序一开始就卡死。然后那群人宁愿重启一次tomcat,也不愿意去改这个开机的顺序。

由于项目之前是使用bonecp的连接池,不太好把这个给改掉,虽然现在很多连接池都是支持断线重连的,但是不能改啊!!!

好吧你既然那么固执,只可以用代码解决了。开始别人说用递归,然后内存很果断的溢出了。最后干脆加了个循环和延迟,暂时把这个问题给解决了。。。

// 初始化连接池
	public void init() {

		while (true) {
			try {
				// 设置数据库连接池
				connectionPool = new BoneCP(this.config());
				this.getConn();
				break;
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				System.out.println("无法配置连接池!");
				try {
					Thread.sleep(3000);
				} catch (InterruptedException e1) {
					// TODO Auto-generated catch block
					e1.printStackTrace();
				}
			}
		}
	}

抱歉!评论已关闭.