java - Spring Hibernate 的 Google Appengine Cloud SQL 问题

标签 java mysql hibernate google-app-engine spring-mvc

我有一个运行在 Amazon EC2 和 MySQL 上的 Spring Hibernate 应用程序。我正在考虑将我的应用程序移植到 Google App Engine,因为 Google 现在支持使用 Google Could SQL 的 MySQL。

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

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

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>

最佳答案

要在 Eclipse 本地主机和应用引擎实例上运行 Google Cloud SQL,您必须核对以下几点。

  1. 使用创建您的 Cloud SQL 实例的同一 Google 帐户登录到您的 eclipse。
  2. 右键单击项目属性转到 Google>Appengine 检查启用 Google Cloud SQL 实例
  3. 为本地主机选择 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
    
  4. 同时配置 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
    
  5. 只需复制您的 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\
    
  6. 驱动程序类名和数据库访问 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
    
  7. 按照所有步骤操作,您可以在 Eclipse 中轻松配置 Google Cloud SQL。

关于java - Spring Hibernate 的 Google Appengine Cloud SQL 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14516319/

相关文章:

java - NoSuchElementException:使用 hasNextLine 找不到行

java - 如何在 session 关闭后使用 hibernate 访问延迟加载的字段?

java - JPA/Hibernate - 共享主键

java - 静态内部类的 Hibernate 验证

java - Android:如何获取 Google Drive 中上传的文件 URL

java - Grails STS 环境中运行时和编译的不同 JRE

java - 使用选择器从队列中读取jms消息

mysql - SQL查询从一个表中获取数据,其中特定列等于其他表中的值

php - 如何将数组解析为 MYSQL IN()?

java - 我可以在 anchor 标记中使用 include 指令吗?