保存数据时mongodb抛出错误(拓扑被破坏)

时间:2016-03-16 07:48:49

标签: javascript node.js mongodb

我正在尝试使用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错误? 请帮忙。

2 个答案:

答案 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的异步调用。