今天听同事说有一个web项目,在本地测试都是可以的,上线后试运行也可以,但是过几个小时就会出错连接池报错的问题。DBCP在项目中使用非常广泛。应该不太会是配置上出错。上apache官网上看了下,发现原来DBCP不同版本的jar包是支持不同版本的JDBC规范的。如下:
- DBCP 1.4 compiles and runs under JDK 1.6 only (JDBC 4)
- DBCP 1.3 compiles and runs under JDK 1.4-1.5 only (JDBC 3)
而JDK对JDBC版本支持的规范如下:
JDK 1.1 - JDBC 1. Note that with the 8.0 release JDBC 1 support has been removed, so look to update your JDK when you update your server.
JDK 1.2, 1.3 - JDBC 2.
JDK 1.3 + J2EE - JDBC 2 EE. This contains additional support for javax.sql classes.
JDK 1.4, 1.5 - JDBC 3. This contains support for SSL and javax.sql, but does not require J2EE as it has been added to the J2SE release.
JDK 1.6 - JDBC4. Support for JDBC4 methods is limited. The driver builds, but the majority of new methods are stubbed out.
而oracle提供的jar一般是10g是支持jdk1.4的,这从它的名字ojdbc14.jar上就能看出来。
那么这样一来,我们项目如果是oracle10g的数据库,那么JDK最好是使用1.4或1.5,DBCP则使用1.4版本,否则容易出现jar包兼容性问题。
(注:不知JDBC各个版本的规范是否具有向下兼容机制,如果是具备向下兼容,那么上述jar选择应该只是可能会造成一些局部代码冲突问题)