1

MySQL を使用して Amazon EC2 で動作する Spring Hibernate アプリケーションを実行しています。Google が Google Could SQL で MySQL をサポートするようになったため、アプリケーションを Google App Engine に移植することを考えています。

したがって、既存のアプリケーションを 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>
4

2 に答える 2

3

Eclipse localhost と appengine インスタンスで Google Cloud SQL を実行するには、次の点をチェックリストに入れる必要があります。

  1. Cloud SQL インスタンスが作成されたのと同じ Google アカウントで Eclipse にログインします。
  2. プロジェクト プロパティを右クリックして、Google > Appengineに移動し、[ Google Cloud SQL インスタンスを有効にする] をオンにします。
  3. 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
    
  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-xxxx.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. Driver ClassName と Database Access 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 を簡単に構成できます。

于 2013-01-25T12:16:20.940 に答える
0

接続の問題だと思います。データベース構成を間違って記述しているか、データベースとアプリケーション間の接続でデータが失われています。

于 2013-01-25T06:16:48.193 に答える