- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
自从我开始开发我的项目(12 个月前!)以来,我一直在为这个问题绞尽脑汁,总是假设我会在准备发布之前找到答案......不幸的是,这不是案例!
基本上,我有一个在 Azure 上运行的相当简单的 Node.js 服务器,使用 mongoose 连接到 MongoLab(现在是 MLab)数据库。
连接代码如下所示:
// Connect to DB
//mongoose.set('debug', true);
mongoose.connect(envConfig.app.db, {
server: {
auto_reconnect: true,
socketOptions: {
keepAlive: 1,
connectTimeoutMS: 30000,
socketTimeoutMS : 30000,
}
},
replset: {
auto_reconnect: true,
socketOptions: {
keepAlive: 1,
connectTimeoutMS: 30000,
socketTimeoutMS : 30000,
}
}
}, function (err) {
if (err) winstonLogger.error(err);
});
mongoose.connection.on('connecting', function () {
console.log('Connecting to MongoDB...');
});
mongoose.connection.on('connected', function () {
console.log('MongoDB connected!');
});
mongoose.connection.on('open', function () {
console.log('MongoDB connection opened!');
});
mongoose.connection.on('error', function (err) {
console.error('Error in MongoDb connection: ' + err.stack);
winstonLogger.error(err);
mongoose.disconnect();
});
mongoose.connection.on('disconnected', function () {
winstonLogger.error('MongoDB disconnected!');
mongoose.connect(envConfig.app.db, {
server: {
auto_reconnect: true,
socketOptions: {
keepAlive: 1,
connectTimeoutMS: 30000,
socketTimeoutMS : 30000,
}
},
replset: {
auto_reconnect: true,
socketOptions: {
keepAlive: 1,
connectTimeoutMS: 30000,
socketTimeoutMS : 30000,
}
}
});
});
mongoose.connection.on('reconnected', function () {
console.log('MongoDB reconnected!');
});
mongoose.connection.on('close', function () {
console.log('MongoDB closed');
});
您看到的所有额外超时选项等都是我尝试解决此问题的一部分(无济于事)。
这是一个典型的请求:
AccessToken.findOne({ token: token })
.maxTime(10000)
.exec(function (err, accessToken) {
// If I even got to here I would be happy
if (err) return done(err);
// If I could consistently get to here, my project would be finished and I would enjoy being alive again
});
所以,当我启动服务器时,一切都运行良好。而且它一直工作得很好......有时是几天,有时是几个小时,有时是几分钟。然而,在某些时候,请求会命中此代码,并且它会......挂起。没有超时,没有错误。没什么。我没有在任何日志中找到任何证据来显示正在发生的事情。我的快速记录器最终放弃了,我得到了类似的信息:
POST /api/auth/verify - - ms - -
因此,此时,我唯一的选择是重新启动服务器,因为我无法完成数据库请求(或超时,或显示错误),无论是出于爱还是金钱。
我在互联网上搜索了一年,希望找到解决方案,但我尝试过的所有方法都导致......没有任何结果......相同的结果。我什至尝试在 Azure 上运行我自己的副本集,而不是使用 MongoLab。同样的问题。我唯一的想法是,这是一个 Azure 问题,没有明显的解决方案,但我真的不热衷于寻找另一台主机。话虽这么说,我不明白为什么 Mongoose 请求不会超时或显示任何错误,即使我设置了 maxTime...
以下是 MongoLab 提供的一些关于我认为可能存在问题的信息: http://docs.mlab.com/connecting/#known-issues ,但正如你所看到的,我已经尝试了他们建议的一切,甚至更多,但没有成功。
我真的很不知所措,整个情况同时令人大脑 NumPy 、心碎和令人难以置信的愤怒。
如果有人有任何想法,我会永远爱你......
提前谢谢您!
-卢克
最佳答案
好的,我已经有一段时间没有遇到这个问题了。我对连接设置做了很多小的更改,但我认为影响最大的是显式设置 ha(高可用性)和 haInterval replset 选项,或者可能将连接代码移动到我的 app.js 的最末尾.
最终的连接代码如下:
// Connect to DB
var connectionOptions = {
replset: {
socketOptions: {
connectTimeoutMS: 300000, // 5 minutes
keepAlive: 120
},
ha: true, // Make sure the high availability checks are on
haInterval: 10000, // Run every 10 seconds
}
};
//mongoose.set('debug', true);
mongoose.connect(envConfig.app.db, connectionOptions, function (err) {
if (err) winstonLogger.error(err);
});
mongoose.connection.on('connecting', function () {
console.log('Connecting to MongoDB...');
});
mongoose.connection.on('connected', function () {
console.log('MongoDB connected!');
});
mongoose.connection.on('open', function () {
console.log('MongoDB connection opened!');
});
mongoose.connection.on('error', function (err) {
winstonLogger.error(err);
mongoose.disconnect();
});
mongoose.connection.on('disconnected', function () {
winstonLogger.error('MongoDB disconnected!');
mongoose.connect(envConfig.app.db, connectionOptions, function (err) {
if (err) winstonLogger.error(err);
});
});
mongoose.connection.on('reconnected', function () {
console.log('MongoDB reconnected!');
});
mongoose.connection.on('close', function () {
winstonLogger.error('MongoDB closed');
});
if (mongoose.connection.db.serverConfig.s.replset) {
mongoose.connection.db.serverConfig.s.replset.on('ha', function(type, data) {
console.log('replset ha ' + type);
});
mongoose.connection.db.serverConfig.s.replset.on('timeout', function () {
winstonLogger.error('MongoDB timeout');
});
}
我还打开了 Azure WebApp 的 AlwaysOn 选项(这似乎没有太大效果,但现在它正在工作,我不会将其关闭!)。
这个问题似乎确实与故障转移后未重新连接有关,但我不能 100% 肯定地说。
希望这能帮助遇到同样问题的其他人...希望我没有操之过急,只是让它在几天内再次停止工作(如果发生这种情况,我会回来的!) .
感谢所有提供建议的人,我永远感激不已:)
关于node.js - Mongoose 在未指定的时间段后停止响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35951957/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!