Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/267.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Tomcat CP中找不到DB2驱动程序,但Commons工作正常?_Java_Spring_Tomcat - Fatal编程技术网

Java Tomcat CP中找不到DB2驱动程序,但Commons工作正常?

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

我正在使用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" />
    <property name="username" value="user" />
    <property name="password" value="pass" />
</bean>

问题是您已经设置了一个用于获取连接的新连接池。新连接池的新代码需要位于类路径上。您是否已将该依赖项添加到项目中

编辑


您使用的是什么版本的tomcat?您还可以发布完整的stacktrace吗?

似乎无法通过Spring使用Tomcat的CP创建数据源(可能是因为Tomcat的CP使用了一些工厂模式)。我目前的巡视情况如下所示:

  • 将Tomcat的DBCP定义为JNDI资源
  • 将JNDI资源加载到Spring中,更多信息

  • 另请参阅已接受的答案,因为它以原始问题中所述的方式解决了问题。

    我假设在configuration one中的应用程序中,您的
    WEB-INF\lib
    文件夹中有以下JAR

  • commons-dbcp.jar
  • jt400.jar
  • (或者可能是某种版本的)

    现在,当使用选项2时,这是一个问题,因为我假设类
    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)