我正在尝试将我的 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 中定义它但没有成功)
弹簧数据.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>
网页.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 异常),因此我不得不将 mysql-connector-java.jar 文件打包到 lib 文件夹中。另外,现在我只是硬编码了 url、用户名和密码,而不是设置它来使用系统属性。
<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>