Grails 2.3.0 和 mysql 连接超时

Posted

技术标签:

【中文标题】Grails 2.3.0 和 mysql 连接超时【英文标题】:Grails 2.3.0 and mysql connection timeout 【发布时间】:2013-10-27 14:03:38 【问题描述】:

我有一个使用此配置连接到 mysql 数据库的 Grails 2.2.3 应用程序:

 production 
    dataSource 
        dbCreate = "update" // one of 'create', 'create-drop','update'
        url = "jdbc:mysql://localhost/database?autoReconnect=true"

        pooled = true
        properties 
            maxActive = 50
            maxIdle = 25
            minIdle = 5
            initialSize = 5
            minEvictableIdleTimeMillis = 1800000
            timeBetweenEvictionRunsMillis = 1800000
            maxWait = 10000

        


    


升级到 Grails 2.3.0 后,它停止工作,并且在应用程序上一个周末不活动后,我得到了这个异常:

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: The last packet successfully received from the server was 50,139,380 milliseconds ago.  The last packet sent successfully to the server was 50,139,380 milliseconds ago. is longer than the server configured value of 'wait_timeout'. You should consider either expiring and/or testing connection validity before use in your application, increasing the server configured values for client timeouts, or using the Connector/J connection property 'autoReconnect=true' to avoid this problem.
at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1116)
at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:3352)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1971)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2151)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2619)
at com.mysql.jdbc.ConnectionImpl.setAutoCommit(ConnectionImpl.java:4997)
... 5 more
Caused by: java.net.SocketException: Write failed: Broken pipe
at jrockit.net.SocketNativeIO.socketWrite(SocketNativeIO.java:46)

有什么想法吗?

【问题讨论】:

Grails 2.3.1 已经发布,所以你可以考虑先更新到那个版本。 我试过了,但我在 2.3.1 上也遇到了同样的错误...... 你看过这张票了吗:***.com/questions/18078777/…它可能对你有帮助! 【参考方案1】:

尝试将以下“testOn”属性添加到您的连接池配置中:

  properties 
    ...
    testOnBorrow = true
    testWhileIdle = true
    testOnReturn = false
    validationQuery = "SELECT 1"
  

值得尝试这些标志的各种组合。为了在您的环境中获得最佳性能,可能需要进行更改。

【讨论】:

【参考方案2】:

这在过去对我们有用

        properties 
            validationQuery="select 1"
            testWhileIdle=true
            timeBetweenEvictionRunsMillis=60000
        

【讨论】:

以上是关于Grails 2.3.0 和 mysql 连接超时的主要内容,如果未能解决你的问题,请参考以下文章

grails应用程序中的Mysql连接超时,在ELB上使用mariadb galera集群

Grails 和 MySQL 连接异常

大型文件上传期间的 Grails 连接超时

Grails Quartz MongoDB 连接不断打开

grails怎样连接mysql数据库

mysql连接超时的问题