Cloudbees,Tomcat和Spring:“无法为连接URL'null'创建类'的JDBC驱动程序'”

时间:2012-11-27 02:52:00

标签: spring tomcat cloudbees

我正在尝试将我的Spring MVC webapp(Hibernate和JPA)部署到Cloudbees中的Tomcat 7 ClickStack,但似乎无法正确配置数据库连接。我尝试过多个教程(提供了许多解决方案),但没有一个有效。如果有人可以查看我下面的配置文件并让我知道如果他们发现任何错误,我们将不胜感激。

错误:

java.lang.NullPointerException
org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class '' for connect URL 'null' 

首先,我使用cloudbees cli将我的数据库绑定到我的应用程序,这样我就不必在cloudbees-web.xml中声明它了:

bees app:bind -a myapp/app -db mydatabase
    application - myapp/app bound to cb-db:myapp/mydatabase as mydatabase

(我也试过解绑数据库并在cloudbees-web.xml和context.xml中定义它而没有成功)

弹簧data.xml中:

<jee:jndi-lookup id="datasource" jndi-name="jdbc/mydatabase"
                 lookup-on-startup="false" proxy-interface="javax.sql.DataSource"
                 cache="true" resource-ref="true"  />

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="persistenceUnitName" value="hibernate-jpa"/>
    <property name="dataSource" ref="dataSource"/>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="databasePlatform" value="org.hibernate.dialect.MySQL5Dialect"/>
            <property name="showSql" value="false"/>
            <property name="generateDdl" value="true"/>
        </bean>
    </property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
    <property name="jpaDialect">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect"/>
    </property>
</bean>

的web.xml:

<resource-ref>
    <res-ref-name>jdbc/mydatabase</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>

我已从我的Maven文件和lib文件夹中的所有jar中删除了对连接器的所有引用。搜索错误消息表明它通常与未找到的驱动程序有关...但由于数据库是由容器提供的,为什么我要担心?

- 编辑:使用META-INF / context.xml文件 -

请注意,许多文档中引用的com.cloudbees.jdbc.Driver不起作用(抛出了一个classnotfound异常),因此我不得不将libql文件夹中的mysql-connector-java.jar文件打包。另外,现在我只是硬编码了网址,用户名和密码,而不是将其设置为使用系统属性。

<Context>
<Loader delegate="true"/>
<Resource
        name="jdbc/mydatabase"
        auth="Container"
        type="javax.sql.DataSource"
        maxActive="5"
        maxIdle="2"
        username="USERNAME"
        maxWait="5000"
        driverClassName="com.mysql.jdbc.Driver"
        password="PASSWORD"
        url="jdbc:mysql://MY_EC2_DB_URL:3306/mydatabase"/>
</Context>

2 个答案:

答案 0 :(得分:1)

我遇到了同样的问题,最终设法“正确”配置了数据源!

我正在使用PropertyPlaceholderConfigurer,如下所示:

<bean id="jpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
   <property name="showSql" value="false" />
   <property name="database" value="MYSQL" />
   <property name="generateDdl" value="false" />
</bean>

<context:property-placeholder system-properties-mode="FALLBACK" />

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
   <property name="driverClassName" value="${dt4j.driver}" />
   <property name="url" value="${dt4j.url}" />
   <property name="username" value="${dt4j.username}" />
   <property name="password" value="${dt4j.password}" />
</bean>

“FALLBACK”表示应该针对任何本地属性解析占位符,然后针对系统属性解析占位符。

最后,我只需要添加系统属性(-Dprop = value)或将它们添加到Cloudbees deployer插件中以使其工作。 必须有更好的方法,但主要目标是实现的:数据源配置在项目中没有硬编码!

答案 1 :(得分:0)

不幸的是,在这个时间点,tomcat7堆栈中没有为您完成JNDI数据库设置。

将数据库绑定到应用程序时 - 它会注入一些系统属性:

MYSQL_PASSWORD_MYDB 
MYSQL_URL_MYDB
MYSQL_USERNAME_MYDB

(MYDB,因为它是您的数据库资源的名称)。然后,您可以在代码/配置中引用它们。 对于tomcat 7,您可以将/META-INF/context.xml放入您的应用程序中,该应用程序将设置JNDI数据源(请参阅http://tomcat.apache.org/tomcat-7.0-doc/jndi-datasource-examples-howto.html