什么是mysql连接超时的最佳解决方案?

时间:2017-02-09 02:55:53

标签: mysql go

我正在Go中编写一个小型Web应用程序,它使用mysql来存储数据。

如果Web服务器在一段时间后(> 8小时)没有收到任何请求,我会出现间歇性的mysql错误:

[mysql] 2017/02/08 16:31:56 packets.go:33: unexpected EOF
[mysql] 2017/02/08 16:31:56 packets.go:130: write tcp 127.0.0.1:49188->127.0.0.1:3306: write: broken pipe

我在github(issue 529issue 257issue 446)上找到了一些相关的讨论。根据我的理解,如果达到超时,mysql db将关闭连接。

我尝试将SetMaxOpenConns设置为9,将SetMaxIdleConns设置为0,正如有些人推荐的那样。但是,这立即引发了异常。 (但如果我将SetMaxIdleConns设置为大于0,则不会立即抛出异常)

我还尝试将SetConnMaxLifetime设置为5分钟。 5分钟后,这也引发了异常。

现在我正在尝试以下代码:

db.SetConnMaxLifetime(0)
db.SetMaxOpenConns(10)
db.SetMaxIdleConns(5)

它已经运行了20分钟。现在还为时过早。 (更新:这也不起作用)

这是配置:

  • 驱动程序:go-sql-driver V1.3。
  • go version:go1.7.1 darwin / amd64
  • mysql:latest from docker hub
  • rkt version:1.18
  • CoreOS:1284.0.0

2 个答案:

答案 0 :(得分:1)

也许你可以开始心跳Goroutine以避免超时。

答案 1 :(得分:1)

  1. 您可以检查mysql time_wait变量:

    mysql> show global variables like 'wait_timeout':
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | wait_timeout  | 300   |
    +---------------+-------+
    1 row in set (0.00 sec)
    
  2. 然后使用db.SetConnMaxLifetime(120*time.Second),这意味着当数据库连接空闲超过120秒时,db.Open将重新打开sql.db或从数据库池中获得新连接。如果未设置连接的最大使用寿命,则可能使用封闭的连接并收到错误消息。

  3. 正在查看mysql进程列表,mysql> show processlist;,如果连接睡眠超过300s,则由mysql回收:

    mysql> show processlist;
    +-------+-----------------+------------------+-------------+---------+---------+------------------------+------------------+
    | Id    | User            | Host             | db          | Command | Time    | State                  | Info             |
    +-------+-----------------+------------------+-------------+---------+---------+------------------------+------------------+
    |     4 | event_scheduler | localhost        | NULL        | Daemon  | 1363480 | Waiting on empty queue | NULL             |
    | 26539 | root            | 172.17.0.1:48732 | NULL        | Query   |       0 | starting               | show processlist |
    | 26575 | auditcenter     | 172.17.0.1:51714 | obs_gb_test | Sleep   |      51 |                        | NULL             |
    +-------+-----------------+------------------+-------------+---------+---------+------------------------+------------------+
    3 rows in set (0.00 sec)
    
  4. SetMaxOpenConnsSetMaxIdleConns用于设置连接资源,请参见enter link description here