首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Google Appengine Cloud SQL与Spring Hibernate的问题

Google Appengine Cloud SQL与Spring Hibernate的问题
EN

Stack Overflow用户
提问于 2013-01-25 14:09:50
回答 2查看 2.4K关注 0票数 1

我有一个运行在亚马逊EC2和MySQL上的Spring Hibernate应用程序。我正在考虑将我的应用程序移植到谷歌应用程序引擎,因为谷歌现在支持MySQL与谷歌可以SQL。

因此,将我现有的应用程序配置为Google App Engine Web应用程序,然后编译代码,没有任何错误。我没有对现有的应用程序做任何更改,它编译并创建了所需的表,服务器成功启动。

但是,当运行通过hibernate访问数据库的应用程序时,我得到了以下错误。

代码语言:javascript
复制
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

代码语言:javascript
复制
<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>
EN

回答 2

Stack Overflow用户

发布于 2013-01-25 20:16:21

要在Eclipse localhost和appengine实例上运行Google Cloud SQL,您必须检查以下几点。

使用创建Cloud SQL实例的同一个google帐户登录到eclipse,右键单击项目属性,选择Google>Appengine,选中instance

  • Choose,为启用Google Cloud
  1. MySQL实例,并配置它的值。

主机名:本地主机数据库名称:您的数据库名称端口号: 3306用户名: yourMySQLUserName密码: MySQL JDBC Jar的yourPassword路径: mysql-connector-java-x.x.xx.jar //我通常也会将此jar放在WEB-INF/lib

  • Configure上Google Cloud SQL实例上:

实例名称:内容//这将出现在Google API控制台数据库名称:您的数据库名称用户名: yourMySQLUserName密码: yourPassword

  • Just下的Google Cloud SQL选项卡下。复制mysql-connector-java-x.x.xx.jar文件并将其粘贴到您的Appengine SDK在Eclipse中的此位置下

//此路径显示为Eclipse驱动程序ClassName,数据库访问URL应更改为以下值。

SQL类名称: com.google.appengine.api.rdbms.AppEngineDriver数据库访问URL : jdbc:google:rdbms://instance_name/database_name例如jdbc:google:rdbms://XXXXXX:xxxxx/XXX_databasename user : username //您的数据库用户默认其根密码: password //您的数据库密码在GAE Cloud AppengineDriver

  • 中默认为空
票数 3
EN

Stack Overflow用户

发布于 2013-01-25 14:16:48

我认为这是一个连接problem.Either,你写错了数据库配置,或者数据库和应用程序之间的连接丢失了数据。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14516319

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档