go-sql-driver发生invalid connection(bad connection)解决方法讨论

niclelin · 2018-05-26 14:55:22 · 16834 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-05-26 14:55:22 的主题,其中的信息可能已经有所发展或是发生改变。

在使用go-sql-driver过程中,有时候我发现会报invalid connection的错误,这个错误产生的原因设置了空闲连接不为0时,客户端拿到连接有可能是已经被服务端关闭了,此时就会发生invalid connection,网上有些解决方案是把空闲连接数设置0,不知道设置为0跟设置为50之类的性能有什么大的区别吗?跪求大神解答!


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

16834 次点击  ∙  1 赞  
加入收藏 微博
5 回复  |  直到 2018-11-12 18:49:31
niclelin
niclelin · #1 · 7年之前

当然这是因为服务端主动关闭了连接,因为服务端对连接的保持超时时间到了也关闭的,所以可以设置客户端连接超时时间小于服务端DB.SetConnMaxLifetime(time.Second)

eric-lc
eric-lc · #2 · 7年之前

因为beego没有调用db.SetConnMaxLifetime 这个方法,导致客户端保持了已经关闭的链接,修改 addAliasWthDB 方法,在方法里面,添加 db.SetConnMaxLifetime(time.Second),time.Second 为数据库闲链接超时时间,而这个时间应该小于数据库设置闲时链接超时时间

niclelin
niclelin · #3 · 6年之前
eric-lceric-lc #2 回复

因为beego没有调用db.SetConnMaxLifetime 这个方法,导致客户端保持了已经关闭的链接,修改 addAliasWthDB 方法,在方法里面,添加 db.SetConnMaxLifetime(time.Second),time.Second 为数据库闲链接超时时间,而这个时间应该小于数据库设置闲时链接超时时间

谢谢,厉害

zhangyasong
zhangyasong · #4 · 6年之前

1538981240(1).jpg

sjw1357
sjw1357 · #5 · 6年之前
eric-lceric-lc #2 回复

因为beego没有调用db.SetConnMaxLifetime 这个方法,导致客户端保持了已经关闭的链接,修改 addAliasWthDB 方法,在方法里面,添加 db.SetConnMaxLifetime(time.Second),time.Second 为数据库闲链接超时时间,而这个时间应该小于数据库设置闲时链接超时时间

666,已解决问题

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传