go orm 报错 packet.go:123 closing bad idle connection

具体报错是:

packet.go:123 closing bad idle connection:unexpected read from socket

connection.go: 173: driver: bad connection

1. 情况:

我是在linux中使用cron任务管理器中遇到的这个问题,每次定时任务会操作数据库,任务函数可以直接允许,但放在cron中每天运行一次的话就会报错

2. 原因:

Mysql server有一个主动断开机制,与客户端的默认交互时间是 8 个小时。然而在orm的连接客户端(client)中连接池的连接,默认与server的连接时长是maxLifetime,是无限的。

因此,连接开启8小时之后,server会主动断开,然而client中的连接池还保存着——当要对数据库进行操作时,client会在连接池中寻找一个空闲的连接,然而这个空闲的连接已经断开,导致了ErrBadConn。

解决原理:只需要把client连接池的连接周期设置成小于server的,这样在server主动断开后,client重连时不会利用已经断开的server连接,而是重新建立连接

3. 解决方案:

在orm包中:

go/pkg/mod/github.com/beego/beego/v2@v2.0.4/client/orm/db_alias.go中的函数中找到

db, err = sql.Open(driverName,dataSource)

db 可以调用函数SetConnMaxLifetime:

db.SetConnMaxLifetime(5*time.Minute)

 这里把client连接池的连接生命周期设置成5分钟(只要小于server默认的交互时间【这里是8h】就可以)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lobster0722

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值