sql server 2008 java 连接字符串函数_java连接sql server 2008数据库代码

在实际项目(多数据源)中发现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的连接池配置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值