MySQL을 사용하는 Amazon EC2에서 작동하는 Spring Hibernate 응용 프로그램이 작동 중입니다. Google Could SQL로 MySQL을 지원하기 때문에 Google App Engine에 애플리케이션을 포팅 할 생각입니다.Spring App Engine Cloud SQL 문제 (Spring Hibernate 포함)
내 기존 응용 프로그램을 Google App Engine 웹 응용 프로그램에 구성한 다음 아무런 오류없이 코드를 컴파일하십시오. 기존 응용 프로그램을 변경하지 않았으며 컴파일하고 필요한 테이블을 만들고 서버를 성공적으로 시작했습니다.
그러나 최대 절전 모드를 통해 데이터베이스에 액세스하는 응용 프로그램을 실행할 때 다음 오류가 발생합니다.
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)
내 엔티티 클래스에 주석을 사용하고 있습니다.
변경해야 할 사항이 있습니까?
아래 나는 당신이 데이터베이스 구성이 잘못 쓰기 problem.Either 연결 또는 데이터베이스와 응용 프로그램 데이터 손실이 사이의 연결 믿고 내 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.driverClassName = com.google.appengine.api.rdbms.AppEngineDriver ** ** jdbc.url = JDBC : 구글 : RDBMS : // localhost를/데이터베이스 ** – zdesam
@zdesam : 나는 똑같은 상황에 직면 해있다. – 1355
@ 1355 당신이 직면 한 문제의 세부 사항을 제공 할 수 있습니까? – zdesam