在实际项目(多数据源)中发现sqlserver连接中断后,无法支持自动重连,拿不到connect:
1.首先通过我的监控页面发现 sqlserver配置的连接池 连接有效性检查类名 为 null。
2.跟踪代码 com.alibaba.druid.pool.DruidDataSource.java initValidConnectionChecker() 方法中, 必须对应是“com.microsoft.jdbc.sqlserver.SQLServerDriver”才会实例化连接有效性检查类,那就是必须使用msbase.jar版本驱动,而我使用的是jtds-1.2.7.jar
3.解决方式A ,替换驱动为 (msbase.jar mssqlserver.jar msutil.jar)。ops!仍然无法解决,可能是我的数据库 是SQLSERVER2008的问题?
4.解决方式B,在2处initValidConnectionChecker()方法(889行)增加条件判断代码,使用jtds驱动也实例化MSSQLValidConnectionChecker.java()
else if (realDriverClassName.equals(JdbcConstants.SQL_SERVER_DRIVER)
||realDriverClassName.equals("net.sourceforge.jtds.jdbc.Driver")
||realDriverClassName.equals("com.microsoft.sqlserver.jdbc.SQLServerDriver")) {
this.validConnectionChecker = new MSSQLValidConnectionChecker();
} 5.使用jtds.jar测试业务通过,sqlserver断线后可自动重连。(模拟网络中断,又恢复网络的情况,每周有个业务系统凌晨要重启路由)
疑问: 1.三种 sqlserver 驱动 ,(msbase.jar mssqlserver.jar msutil.jar)、(sqljdbc4.jar)、(jtds-1.2.7.jar) 都调用 MSSQLValidConnectionChecker.java 作为校验类是否有其他问题?
2.另外必须配置validationQueryTimeout参数,默认为-1 ,不启动检查.
3.请文少和其他大神评估是否有其他影响,希望采纳意见,我是在1.0.15版本下改的测试没问题,目前jtds-1.2.7.jar 驱动用的企业应该更多。
4.附spring-mybatis.xml 关于sqlserver的连接池配置