使用集群 mongo 实例时 mongodb i/o 超时

标签 mongodb go mgo

我有一个应用程序正在使用 upper.io/db 包与 Mongo 数据库服务器进行通信(它是 gopkg.in/mgo.v2< 的一个相当简单的包装器)。应用程序的工作方式是它在启动时在主线程中创建一个 session ,然后每个需要向 mongo 服务器发出请求的 go 例程调用 session 上的 Clone 并执行defer session.Close 结果值。据我所知,这都是标准操作程序。

此设置在我们使用本地运行的 MongoDB MongoLab 上的沙箱实例的开发环境中没有任何错误。最近,我们将该应用程序提升到我们的暂存环境,在那里我们让应用程序与 MongoLab 上的 MongoDB 共享集群实例进行通信(最便宜的 15 美元选项)。这就是奇怪开始发生的地方。通过的/first/请求(从被调用的第一个 go-routine 开始)返回预期的响应,但后续的都返回

 read tcp <ip address>:47112: i/o timeout

这既发生在我们指向集群的本地开发机器上,也发生在用于暂存环境的 AWS 主机上。由于 Mongo 集群来自 Mongolabs,我假设他们已经正确配置了所有内容。

代码有点无聊TBH:它实际上只是在主函数中打开 session 并维护对它的引用,然后有多个具有这种基本结构的goroutines:

   sess := session.Clone()
   defer sess.Close()

   // make requests to Mongo

在测试期间,我什至限制它一次只能运行一件事(即在任何给定时间只有一个 goroutine 处于事件状态),但它仍然以同样的方式失败。

有人遇到过这个吗?我需要以特定方式配置 upper.io/db 吗?也许直接使用mgo?我对此束手无策:(

最佳答案

在一个相当漫长而艰苦的过程中,我们终于找到了这个问题和类似问题在我们的程序中的来源。它最终成为 upper.io/db 库的 v1 版本中的 session 泄漏。错误和修复是 outlined here , 但是这个库的 v1 版本在这一点上已经过时了,以后的版本不会出现这个问题。

我怀疑这个答案对游戏这么晚的任何人都有用(特别是因为我们自己解决了它,就像...... 3 年前的这个时候),但只是想在这里留下答案以保持完整性。

关于使用集群 mongo 实例时 mongodb i/o 超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32405742/

相关文章:

Golang MongoDB 错误 : result argument must be a slice address - (Arrays)

struct - MGO/GOLANG : Struct to unmarshall a document with

mongodb - 这些是 mgo 的相同版本/发行版吗?

node.js - TypeError : restify.authorizationParser不是 Node 中的函数

mongodb 平衡器不会停止

go - 确定 POST 数据值是否匹配结构字段类型

multithreading - 在golang中并行递归扫描树

javascript - 从控制台将 MongoDB 字段的类型更改为整数

MongoDB - 用户权限

sockets - 访问 net/http 响应的底层套接字