2015-08-07 7 views
6

Ich entwickelte eine kleine Heroku + Grails + Postreg-Anwendung. Es wäre fein etwas 20 Minuten nach dem Einsatz arbeiten, danach habe ich immer bekommen:Heroku Postgres: Diese Verbindung wurde geschlossen

This connection has been closed.. Stacktrace follows: Heroku/myapp 
- org.postgresql.util.PSQLException: This connection has been closed. Heroku/myapp 
- at org.postgresql.jdbc2.AbstractJdbc2Connection.checkClosed(AbstractJdbc2Connection.java:837) Heroku/myapp 
- at org.postgresql.jdbc2.AbstractJdbc2Connection.getAutoCommit(AbstractJdbc2Connection.java:798) Heroku/myapp 
- at org.grails.datastore.gorm.GormStaticApi$_methodMissing_closure2.doCall(GormStaticApi.groovy:102) Heroku/myapp 
- at com.myapp.WorkspaceController.list(WorkspaceController.groovy:18) Heroku/myapp 
- at grails.plugin.cache.web.filter.PageFragmentCachingFilter.doFilter(PageFragmentCachingFilter.java:198) Heroku/myapp 
- at grails.plugin.cache.web.filter.AbstractFilter.doFilter(AbstractFilter.java:63) Heroku/myapp 
- at grails.plugin.springsecurity.web.filter.GrailsAnonymousAuthenticationFilter.doFilter(GrailsAnonymousAuthenticationFilter.java:53) Heroku/myapp 
- at grails.plugin.springsecurity.web.authentication.RequestHolderAuthenticationFilter.doFilter(RequestHolderAuthenticationFilter.java:53) Heroku/myapp 
- at grails.plugin.springsecurity.web.authentication.logout.MutableLogoutFilter.doFilter(MutableLogoutFilter.java:62) Heroku/myapp 
- at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) Heroku/myapp 
- at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) Heroku/myapp 
- at java.lang.Thread.run(Thread.java:745) Heroku/myapp 
- 2015-08-07 15:11:10,685 [http-nio-20850-exec-5] ERROR spi.SqlExceptionHelper - This connection has been closed. Heroku/myapp 
- 2015-08-07 15:11:10,689 [http-nio-20850-exec-5] ERROR spi.SqlExceptionHelper - This connection has been closed. Heroku/myapp 
- 2015-08-07 15:11:10,696 [http-nio-20850-exec-5] ERROR errors.GrailsExceptionResolver - PSQLException occurred when processing request: [GET] /api/users/21/workspaces Heroku/myapp 
- This connection has been closed.. Stacktrace follows: Heroku/myapp 
+0

können Sie Ihre Datenquelle Einstellungen innerhalb grails einfügen? –

Antwort

6

ich es selbst durch diese Zugabe zu DataSource.groovy gelöst haben:

dataSource { 
    pooled = true 
    properties { 
     maxActive = -1 
     minEvictableIdleTimeMillis=1800000 
     timeBetweenEvictionRunsMillis=1800000 
     numTestsPerEvictionRun=3 
     testOnBorrow=true 
     testWhileIdle=true 
     testOnReturn=true 
     validationQuery="SELECT 1" 
    } 
} 
+0

Irgendeine Idee, welche dieser Eigenschaften tatsächlich den Unterschied machte? – Jonik

+1

Ich hatte das gleiche Problem in einer Spring Boot App (mit [DataSource] (https://tomcat.apache.org/tomcat-8.0-doc/api/org/apache/tomcat/jdbc/pool/DataSource.html) von Tomcat JDBC), und sieht so aus, als hätte ich es mit 'setTestOnBorrow (true) gelöst; setTestWhileIdle (true); setTestOnReturn (Wahr); setValidationQuery ("SELECT 1"); '([javadocs] (https://tomcat.apache.org/tomcat-8.0-doc/api/org/apache/tomcat/jdbc/pool/DataSourceProxy.html#setTestOnBorrow (boolean))). Vielen Dank! – Jonik

2

Eine Kombination von @ Macchiatow Antwort und @ Jonik Kommentar, das ist, was ich mit weniger Eigenschaften zu arbeiten, verwendet:

dataSource { 
    pooled = true 
    properties { 
     testOnBorrow = true 
     testWhileIdle = true 
     testOnReturn = true 
     validationQuery = "SELECT 1" 
    } 
    driverClassName = "org.postgresql.Driver" 
    dialect = "..." 
}