tomcat服务器上的jdbc连接

时间:2011-12-14 17:02:41

标签: apache tomcat jdbc connection

我会尽力尽力制定。

首先,Web应用程序(带有Spring Jdbc的Spring MVC)运行良好,直到我开始搞乱使用STS(基于Eclipse的Spring Tool Suite)和JDK + JRE7的版本来获取Java 7的功能。

其次,当前的问题是Apache Tomcat 6或7(我有两个我因为我不记得的原因重新安装)似乎正在影响与数据库的连接。直接说:它无法获得jdbc连接

 org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is java.sql.SQLException: No suitable driver found for jdbc:postgresql:postgres

每当我尝试从我的Web应用程序对数据库执行任何操作时就会发生这种情况。

行jdbc:postgresql:postgres是好的以防万一,因为它之前有效,它有效地说连接到名为postgres的本地数据库(也因为下面的点)。

另一个值得一提的重点是,在vFabric tc Server下,一切都能正常运行,没有任何问题。

第三,数据库是PostgreSql以及Apache DBCP池。

第四,maven jdbc驱动程序依赖项似乎运行良好,如果它们没有vFabric tc Server也会像Apache Tomcat一样失败,这导致我认为Apache Tomcat本身就是罪魁祸首。

服务器启动期间产生的一些信息:

     Dec 14, 2011 4:54:32 PM org.apache.catalina.core.AprLifecycleListener init
     INFO: The APR based Apache Tomcat Native library which allows optimal                       performance in production environments was not found on the java.library.path:           C:\ProgramFiles\Java\jdk1.7.0_02\bin;C:\Windows\Sun\Java\bin;C:\Windows\system32;C:\Windows;C:\Program Files (x86)\MiKTeX 2.9\miktex\bin;C:\Program Files\Apache Software Foundation\apache-maven-3.0.3\bin;C:\Program Files (x86)\NVIDIA Corporation\PhysX\Common;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files\Intel\WiFi\bin\;C:\Program Files\Common Files\Intel\WirelessCommon\;C:\Program Files\WIDCOMM\Bluetooth Software\;C:\Program Files\WIDCOMM\Bluetooth Software\syswow64;C:\Program Files (x86)\Microsoft SQL Server\100\Tools\Binn\;C:\Program Files\Microsoft SQL Server\100\Tools\Binn\;C:\Program Files\Microsoft SQL Server\100\DTS\Binn\;C:\Program Files (x86)\QuickTime\QTSystem\;.
     Dec 14, 2011 4:54:32 PM org.apache.coyote.AbstractProtocol init
     INFO: Initializing ProtocolHandler ["http-bio-8080"]
     Dec 14, 2011 4:54:32 PM org.apache.coyote.AbstractProtocol init
     INFO: Initializing ProtocolHandler ["ajp-bio-8009"]
     Dec 14, 2011 4:54:32 PM org.apache.catalina.startup.Catalina load
     INFO: Initialization processed in 849 ms
     Dec 14, 2011 4:54:32 PM org.apache.catalina.core.StandardServicestartInternal
     INFO: Starting service Catalina
     Dec 14, 2011 4:54:32 PM org.apache.catalina.core.StandardEngine startInternal
     INFO: Starting Servlet Engine: Apache Tomcat/7.0.23
     Dec 14, 2011 4:54:33 PM org.apache.catalina.startup.HostConfig deployDescriptor
     INFO: Deploying configuration descriptor C:\Users\User\Documents\workspace-sts\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\conf\Catalina\localhost\project.xml
     Dec 14, 2011 4:54:33 PM org.apache.catalina.startup.SetContextPropertiesRule begin
     WARNING: [SetContextPropertiesRule]{Context} Setting property 'source' to 'org.eclipse.jst.jee.server:project' did not find a matching property.
     Dec 14, 2011 4:54:34 PM org.apache.catalina.core.ApplicationContext log
     INFO: Initializing Spring root WebApplicationContext

     Dec 14, 2011 4:54:37 PM org.apache.coyote.AbstractProtocol start
     INFO: Starting ProtocolHandler ["http-bio-8080"]
     Dec 14, 2011 4:54:37 PM org.apache.coyote.AbstractProtocol start
     INFO: Starting ProtocolHandler ["ajp-bio-8009"]
     Dec 14, 2011 4:54:37 PM org.apache.catalina.startup.Catalina start
     INFO: Server startup in 4664 ms

我非常绝望,请帮助。

更新

仍然坐在前面看悲伤的屏幕,所以我决定包括所有的.xml配置。

<bean id="dataSource" class="org.apache.commons.dbcp.PoolingDataSource">
    <constructor-arg ref="connectionPool"/>
</bean>

<bean id ="connectionPool" class="org.apache.commons.pool.impl.GenericObjectPool">
<constructor-arg><null/></constructor-arg>
</bean>


<bean id="poolableConnectionFactory" class="org.apache.commons.dbcp.PoolableConnectionFactory" >
<constructor-arg ref="connectionFactory"/>
<constructor-arg ref="connectionPool"/>
<constructor-arg><null/></constructor-arg>
<constructor-arg><null/></constructor-arg>
<constructor-arg value="false"/>
<constructor-arg value="true"/>
</bean>

    <bean id="connectionFactory" class="org.apache.commons.dbcp.DriverManagerConnectionFactory">
    <constructor-arg value="jdbc:postgresql:postgres"/>
    <constructor-arg value="postgres"/>
    <constructor-arg value="myCorrectPassword"/>
</bean>

1 个答案:

答案 0 :(得分:2)

在grl中,我会说DB驱动程序应该进入Tomcat上的公共lib文件夹。 通常这些驱动程序用于多种应用程序。

此外,如果在context.xml中设置池,则需要这样做。