我正在尝试使用Node.js将数据写入MongoDB 在写入数据时,我在最后一行收到以下错误。 执行日志是:
{ _id: 56e90c1292e69900190954f5,
nfs: [ 'ebdp1', 'ebdp2', 'ebdp3', 'ebdp4' ],
snapShotTime: '2016-03-16 07:32:34' }
{ [MongoError: topology was destroyed] name: 'MongoError', message: 'topology was destroyed' }
我的代码结构是根据框架,其中Collection的架构在appTableProdSchema.js
文件中,而对象数据在appTableProdData.js
文件中。
Main是newMain.js
代码如下: newMain.js
var mongoose = require('mongoose');
var moment = require('moment');
var nfs_check="";
var promises = [];
var nodes = ["ebdp1","ebdp2", "ebdp3", "ebdp4"];
mongoose.connect('mongodb://localhost:27017/test');
var db = mongoose.connection;
var storageData = require('./appTableProdData.js');
var storageDataSchema = require('./appTableProdSchema.js');
var obj = {};
obj.snapShotTime = moment().utc().format("YYYY-MM-DD HH:mm:ss");
obj.nfs = nodes;
db.once('open', function() {
var mongoData = new storageData();
mongoData.fill(obj);
var promise = new storageDataSchema(mongoData.getInformation());
console.log(promise.toString());
promise.save(function (err, promise) {
if (err) return console.error(err);
promise.speak();
});
});
mongoose.disconnect();
appTableProdSchema.js
var mongoose = require('mongoose');
module.exports = mongoose.model('AppTableProd', {
snapShotTime : String,
nfs: Array
});
appTableProdData.js
var storageData = function() {
this.data = {
snapShotTime: null,
nfs: null
};
this.fill = function(resp) {
this.data.snapShotTime = resp.snapShotTime;
this.data.nfs = resp.nfs;
};
this.getInformation = function() {
return this.data;
};
};
module.exports = storageData;
我知道为什么会出现topology destroyed
错误?
请帮忙。
答案 0 :(得分:5)
你的
sample1.txt
在
之前被调用mongoose.disconnect();
此代码块正在执行,因为它是异步调用。
你应该叫这个
db.once('open', function() {
var mongoData = new storageData();
mongoData.fill(obj);
var promise = new storageDataSchema(mongoData.getInformation());
console.log(promise.toString());
promise.save(function (err, promise) {
if (err) return console.error(err);
promise.speak();
});
});
像这样
mongoose.disconnect();
答案 1 :(得分:1)
这是一个常见问题,mongoose是异步运行的,你不能在脚本末尾使用mongoose.disconnect();
,这是一种同步方式。
Topology destroyed
表示您在尝试在数据库中插入内容时同时关闭连接。这是他正在启动的nodejs的行为(并行所有异步进程)。
在这种情况下,请尝试删除mongoose.disconnect();
。或者确保在关闭连接之前没有对mongodb的异步调用。