node.js – 处理MongoDB断开/重新连接Node

当我的MongoDB连接空闲几分钟时,下一个请求以错误结束.从mongo命令行客户端,它看起来像这样:

> db.users.find()
Sat Jan 12 23:42:35 Socket recv() errno:54 Connection reset by peer 107.22.25.25:47207
Sat Jan 12 23:42:35 SocketException: remote: 107.22.25.25:47207 error: 9001 socket exception [1] server [107.22.25.25:47207] 
Sat Jan 12 23:42:35 DBClientCursor::init call() Failed
Sat Jan 12 23:42:35 query Failed : chowology.users {} to: ds047207.mongolab.com:47207
Error: error doing query: Failed
Sat Jan 12 23:42:35 trying reconnect to ds047207.mongolab.com:47207
Sat Jan 12 23:42:35 reconnect ds047207.mongolab.com:47207 ok

我看到针对MongoHQ和MongoLab的沙盒实例的问题.

由于重新连接,下一个请求会很好.这是我的网络应用程序中的一个问题,因为在几分钟不活动后,在Web请求期间会出现此错误.有两件事让我感到惊讶:

> MongoDB连接被定期和频繁地销毁,并且
>驱动程序只是引发异常,而不是在重新连接后自动重试(我使用的是使用mongoose的connect-mongo,而mongoose又使用了node-mongodb-native).

这是其他人的经历吗?怎么应该处理?如果应用程序开发人员将他们的数据库操作包装在一些重试异常处理废话中,我会感到惊讶.

解决方法

您想查看Server对象的文档

http://mongodb.github.com/node-mongodb-native/api-generated/server.html#server

特别是socketoptions,您可以在其中设置keepAlive和连接超时.认情况下,keepalive处于关闭状态,超时为0或从不表示os套接字超时有效(从os到os不等).保持活动状态会在tcp套接字连接中偶尔发送一个数据包以使其保持活动状态.有时防火墙配置不当,并且在关闭连接时不会发送结束数据包,导致连接死机并处于不明确状态,这是单声道人们正在谈论的内容(更常见的是,他们的配置非常糟糕).

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...