在Heroku项目的mysql中获取通信链接失败错误

时间:2014-02-20 18:41:52

标签: mysql spring hibernate heroku cleardb

我正在使用Heroku上的Spring hibernate项目并使用ClearDB。当我的页面闲置一段时间(几乎一分钟),然后我向服务器发送一些请求时,我得到如下错误:

HTTP ERROR 500

Problem accessing /authenticate.action. Reason:

Communications link failure

Last packet sent to the server was 16 ms ago.; nested exception is    org.hibernate.exception.JDBCConnectionException: Communications link failure

Last packet sent to the server was 16 ms ago.
Caused by:

org.springframework.dao.DataAccessResourceFailureException: Communications link failure

Last packet sent to the server was 16 ms ago.; nested exception is org.hibernate.exception.JDBCConnectionException: Communications link failure

Last packet sent to the server was 16 ms ago.
at     org.springframework.orm.hibernate3.SessionFactoryUtils.convertHibernateAccessException(SessionFactoryUtils.java:631)
at     org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:104)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:403)
at org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible(ChainedPersistenceExceptionTranslator.java:58)
at org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:213)
at org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:163)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)
at sun.proxy.$Proxy33.authenticate(Unknown Source)
Caused by: org.hibernate.exception.JDBCConnectionException: Communications link failure

Last packet sent to the server was 16 ms ago.
at org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:131)
at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:49)
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125)
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110)
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation(AbstractStatementProxyHandler.java:129)
at org.hibernate.engine.jdbc.internal.proxy.AbstractProxyHandler.invoke(AbstractProxyHandler.java:81)
at sun.proxy.$Proxy75.executeQuery(Unknown Source)

我尝试在网上查找答案,并按照以下方式进行了一些配置设置:

继承我的数据源配置:

<beans:bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<beans:property name="url" value="#{ 'jdbc:mysql://' + @dbUrl.getHost() +  @dbUrl.getPath()  + '?reconnect=true'}"/>
<beans:property name="username" value="#{ @dbUrl.getUserInfo().split(':')[0] }"/>
<beans:property name="password" value="#{ @dbUrl.getUserInfo().split(':')[1] }"/>
<beans:property name="minEvictableIdleTimeMillis" value="1800000"/>

每次我离开页面闲置一分钟左右时,我仍然会收到错误。如果我对服务器的请求不停,我不会收到此错误。

我的理解是,这与连接池中的空闲连接有关。当我在本地计算机上运行数据库时,我从未遇到此错误。它只在Heroku上得到这个错误。还有其他人有类似的问题吗?

谢谢, 基兰

0 个答案:

没有答案