Spring Hibernate 的 Google Appengine Cloud SQL 问题
Posted
技术标签:
【中文标题】Spring Hibernate 的 Google Appengine Cloud SQL 问题【英文标题】:Google Appengine Cloud SQL issue with Spring Hibernate 【发布时间】:2013-01-09 02:13:55 【问题描述】:我有一个使用 mysql 在 Amazon EC2 上运行的 Spring Hibernate 应用程序。我正在考虑将我的应用程序移植到 Google App Engine,因为 Google 现在支持 MySQL 和 Google Can SQL。
所以将我现有的应用程序配置为 Google App Engine Web 应用程序,然后编译代码没有任何错误。我没有对现有应用程序进行任何更改,它编译并创建了所需的表,服务器成功启动。
但是,当运行通过休眠访问数据库的应用程序时,我收到以下错误。
org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Cannot open connection
at org.springframework.orm.hibernate3.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:596)
at org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:371)
at org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:335)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:105)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)
at $Proxy30.findById(Unknown Source)
at com.openentry.catgen.services.impl.WebsiteServiceImpl.getMasterDomain(WebsiteServiceImpl.java:99)
我正在为我的实体类使用注释。
我有什么需要改变的吗?
下面是我的 applicationContext.xml
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource"
p:driverClassName="$jdbc.driverClassName" p:url="$jdbc.url"
p:username="$jdbc.username" p:password="$jdbc.password" />
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"
p:dataSource-ref="dataSource" p:configurationClass="org.hibernate.cfg.AnnotationConfiguration"
p:packagesToScan="com.package.app.entities">
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">$hibernate.dialect</prop>
<prop key="hibernate.show_sql">$hibernate.show_sql</prop>
<prop key="hibernate.format_sql">$hibernate.format_sql</prop>
<prop key="hibernate.generate_statistics">$hibernate.generate_statistics</prop>
<prop key="hibernate.connection.useUnicode">$hibernate.connection.useUnicode</prop>
<prop key="hibernate.connection.characterEncoding">$hibernate.connection.characterEncoding</prop>
<prop key="hibernate.connection.charSet">$hibernate.connection.charSet</prop>
<prop key="hibernate.hbm2ddl.auto">$hibernate.hbm2ddl.auto</prop>
</props>
</property>
</bean>
<tx:annotation-driven />
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager"
p:sessionFactory-ref="sessionFactory" />
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<constructor-arg>
<ref bean="sessionFactory" />
</constructor-arg>
</bean>
【问题讨论】:
只需更改两个 jdbc 属性即可一切正常jdbc.driverClassName=com.google.appengine.api.rdbms.AppEngineDriver jdbc.url=jdbc:google:rdbms ://localhost/数据库 @zdesam:我面临同样的情况。你能帮帮我吗 @1355 能否提供您所面临问题的详细信息 【参考方案1】:要在 Eclipse localhost 和 appengine 实例上运行 Google Cloud SQL,您必须检查以下几点。
-
使用创建 Cloud SQL 实例的同一 Google 帐户登录到您的 Eclipse。
右键单击项目属性转到 Google>Appengine 选中 启用 Google Cloud SQL 实例
为 localhost 选择 MySQL 实例并配置其值。
Hostname : localhost
Database Name : yourdatabasename
Port No : 3306
Username : yourMySQLUserName
Password : yourPassword
Path to MySQL JDBC Jar : Path where your mysql-connector-java-x.x.xx.jar // I usually put this jar on the WEB-INF/lib
同时配置 Google Cloud SQL 实例:
Instance Name : something:something // This you will get under Google Cloud SQL tab under Google API Console
Database Name : yourdatabasename
Username : yourMySQLUserName
Password : yourPassword
只需复制 mysql-connector-java-x.x.xx.jar 文件并将其粘贴到 Eclipse 中 Appengine SDK 的此位置下
// This path is shown for Eclipse
D:\MyEclipse\plugins\com.google.appengine.eclipse.sdkbundle_1.7.2.1\appengine-java-sdk-1.7.2.1\lib\impl\
驱动程序类名和数据库访问 URL 应更改为以下值。
AppengineDriver Class Name : com.google.appengine.api.rdbms.AppEngineDriver
Database Access URL : jdbc:google:rdbms://instance_name/database_name
e.g. jdbc:google:rdbms://XXXXXX:xxxxx/XXX_databasename
user : username // Your Database User by default its root
password : password // Your Database Password by default its blank in GAE Cloud SQL
按照所有操作,您可以在 Eclipse 中轻松配置 Google Cloud SQL。
【讨论】:
【参考方案2】:我认为是连接问题。要么你写的数据库配置错误,要么数据库和应用程序之间的连接有数据丢失。
【讨论】:
以上是关于Spring Hibernate 的 Google Appengine Cloud SQL 问题的主要内容,如果未能解决你的问题,请参考以下文章