Java Tomcat CP中找不到DB2驱动程序,但Commons工作正常?
我正在使用tomcat+spring。使用以下配置时:Java Tomcat CP中找不到DB2驱动程序,但Commons工作正常?,java,spring,tomcat,Java,Spring,Tomcat,我正在使用tomcat+spring。使用以下配置时: <bean id="dataSource" class="org.apache.tomcat.dbcp.dbcp.BasicDataSource"> <property name="driverClassName" value="com.ibm.db2.jcc.DB2Driver" /> <property name="url" value="url" /> <propert
<bean id="dataSource" class="org.apache.tomcat.dbcp.dbcp.BasicDataSource">
<property name="driverClassName" value="com.ibm.db2.jcc.DB2Driver" />
<property name="url" value="url" />
<property name="username" value="user" />
<property name="password" value="pass" />
</bean>
问题是您已经设置了一个用于获取连接的新连接池。新连接池的新代码需要位于类路径上。您是否已将该依赖项添加到项目中 编辑
您使用的是什么版本的tomcat?您还可以发布完整的stacktrace吗?似乎无法通过Spring使用Tomcat的CP创建数据源(可能是因为Tomcat的CP使用了一些工厂模式)。我目前的巡视情况如下所示:
另请参阅已接受的答案,因为它以原始问题中所述的方式解决了问题。我假设在configuration one中的应用程序中,您的
WEB-INF\lib
文件夹中有以下JAR
org.apache.tomcat.jdbc.pool.DataSource
来自tomcat\lib文件夹中的jar,而不是来自WEB-INF\lib文件夹。由于org.apache.tomcat.jdbc.pool.DataSource
是由系统类加载器而不是web应用程序类加载器加载的,因此它无法从web-INF\lib
目录中的JAR中查看类
所以,要么把你的jt400.jar放在
tomcat\lib
目录中,要么把tomcat-jdbc.jar放在WEB-INF\lib
文件夹中。你把jdbc jar文件准备好放在lib文件夹中了吗?@BMW我必须把它放在lib中,否则第1个配置无法工作……不,它们属于不同的目录jars@BMW是的,但我使用eclipse,它在服务器配置之后默认添加了tomct/lib。我100%确定Tomact的CP在类路径上。并不是说我的CP失踪了,而是司机-是吗?但它不能错过,因为,第一配置工作。我的想法。通过更改Tomcat的CP忽略lib文件夹,您可以更具体一点吗。是否依赖于DB2驱动程序或Tomcat的CP?我使用Tomcat,所以CP必须在类路径上。DB2驱动程序也在类路径上,因为第1个配置(使用公共cp)可以工作。7.0.42一些随机文本,为了满足该版本的纵向注释要求,tomcat连接池应该存在于lib中。实际上它可以工作。。。老实说,我不明白为什么。我没有commons dbcp,但在tomcat/lib中有tomcat dbcp(据我所知基本相同),tomcat jdbc也存在。所以这是非常奇怪的,一个CP看到驱动程序,而第二个CP看不到驱动程序。无论如何,回答的道具。没有注意到org.apache.tomcat.dbcp.dbcp.BasicDataSource
被忽略,因为BasicDataSource
我假设您使用了普通的dbcp。Tomcat默认使用Tomcat jdbc impl作为其数据源,因此它可能也会被急切地加载到系统类加载器中,而不是Tomcat dbcp one。也许这就是它的工作方式。再次感谢你们以我想要的方式解决了这个问题。
<bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource">
<property name="driverClassName" value="com.ibm.db2.jcc.DB2Driver" />
<property name="url" value="url" />
<property name="username" value="user" />
<property name="password" value="pass" />
</bean>
exception
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.sql.SQLException: com.ibm.db2.jcc.DB2Driver
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:973)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:108)
root cause
java.sql.SQLException: com.ibm.db2.jcc.DB2Driver
org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:254)
org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:182)
org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:702)
org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:634)
org.apache.tomcat.jdbc.pool.ConnectionPool.init(ConnectionPool.java:488)
org.apache.tomcat.jdbc.pool.ConnectionPool.<init>(ConnectionPool.java:144)
org.apache.tomcat.jdbc.pool.DataSourceProxy.pCreatePool(DataSourceProxy.java:116)
org.apache.tomcat.jdbc.pool.DataSourceProxy.createPool(DataSourceProxy.java:103)
org.apache.tomcat.jdbc.pool.DataSourceProxy.getConnection(DataSourceProxy.java:127)
spring.controller.ReviewController.getReviewById(ReviewController.java:25)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:606)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:215)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:749)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:690)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:83)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:108)
root cause
java.lang.ClassNotFoundException: com.ibm.db2.jcc.DB2Driver
java.net.URLClassLoader$1.run(URLClassLoader.java:366)
java.net.URLClassLoader$1.run(URLClassLoader.java:355)
java.security.AccessController.doPrivileged(Native Method)
java.net.URLClassLoader.findClass(URLClassLoader.java:354)
java.lang.ClassLoader.loadClass(ClassLoader.java:424)
java.lang.ClassLoader.loadClass(ClassLoader.java:357)
java.lang.Class.forName0(Native Method)
java.lang.Class.forName(Class.java:270)
org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:246)
org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:182)
org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:702)
org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:634)
org.apache.tomcat.jdbc.pool.ConnectionPool.init(ConnectionPool.java:488)
org.apache.tomcat.jdbc.pool.ConnectionPool.<init>(ConnectionPool.java:144)
org.apache.tomcat.jdbc.pool.DataSourceProxy.pCreatePool(DataSourceProxy.java:116)
org.apache.tomcat.jdbc.pool.DataSourceProxy.createPool(DataSourceProxy.java:103)
org.apache.tomcat.jdbc.pool.DataSourceProxy.getConnection(DataSourceProxy.java:127)
spring.controller.ReviewController.getReviewById(ReviewController.java:25)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:606)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:215)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:749)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:690)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:83)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:108)