javascript - nodeJS 模块 Mongoose 给我错误

标签 javascript node.js mongodb mongoose database

当我运行我的代码时,我得到一个错误 我想做的是当有人登录到我的网站时,它会将 IP 和其他数据记录到数据库中。它似乎有效,但后来我收到此错误并退出了我的应用程序

{ [Error: Trying to open unclosed connection.] state: 1 }
Connection to database has been established

/home/azura/node_modules/mongoose/lib/index.js:343
      throw new mongoose.Error.OverwriteModelError(name);
        ^
OverwriteModelError: Cannot overwrite `dataType` model once compiled.
    at Mongoose.model (/home/azura/node_modules/mongoose/lib/index.js:343:13)
at Namespace.<anonymous> (/home/azura/Desktop/dbWrite.js:19:37)
at Namespace.EventEmitter.emit (events.js:95:17)
at Namespace.emit (/home/azura/node_modules/socket.io/lib/namespace.js:205:10)
at /home/azura/node_modules/socket.io/lib/namespace.js:172:14
at process._tickCallback (node.js:415:13)

我使用的代码是:

var mongoose = require("mongoose");
var express = require("express");
var app = express();
var http = require("http").Server(app);
var io = require("socket.io")(http);
app.get("/", function (req, res) {
    res.sendFile(__dirname + "/index.html");
});
io.on("connection", function (socket) {
    var ip = socket.request.socket.remoteAddress;
    var dataBase = mongoose.connection;
    mongoose.connect("mongodb://localhost:27017/NEW_DB1");
    dataBase.on("error", console.error);
    console.log("Connection to database has been established");
    var collectedData = new mongoose.Schema({
        ipAddress: String,
        time: Number
    });
    var collectionOfData = mongoose.model("dataType", collectedData);
    var Maindata = new collectionOfData({
        ipAddress: ip,
        time: 100000000000000000
    });
    Maindata.save(function (err, Maindata) {
        if (err) {
            return console.error(err);
        } else {
            console.dir(Maindata);
        }
    });
});
http.listen(10203, function () {
    console.log("Server is up");
});

index.html 文件没有任何重要内容。 我只是想知道为什么我会收到此错误。 我该怎么做才能修复它?

最佳答案

将此代码置于连接范围之外。无需为每种类型创建新连接事件的模式。

mongoose.connect("mongodb://localhost:27017/NEW_DB1");
dataBase.on("error", console.error);
console.log("Connection to database has been established");
var collectedData = new mongoose.Schema({
    ipAddress: String,
    time: Number
});
var collectionOfData = mongoose.model("dataType", collectedData);




io.on("connection", function (socket) {
    var ip = socket.request.socket.remoteAddress;
    var dataBase = mongoose.connection;
    var Maindata = new collectionOfData({
        ipAddress: ip,
        time: 100000000000000000
    });
    Maindata.save(function (err, Maindata) {
        if (err) {
            return console.error(err);
        } else {
            console.dir(Maindata);
        }
    });
});

关于javascript - nodeJS 模块 Mongoose 给我错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31800073/

相关文章:

javascript - 错误 : data and salt arguments required

c# - 在 MongoDB 集合中获取前 10 个结果

javascript - Meteor从两个通过id映射的集合中获取数据

javascript - Flowtype Javascript 推理未按预期工作

javascript - CSS::first-letter drop cap 忽略 $ 符号。有 Polyfill 吗?

node.js - 在哪里破坏knex连接

javascript - 遍历所有集合并删除它们

javascript - 仅允许数字和字母在 Mozilla Firefox 中不起作用

javascript - 如何在 VueJS 中将对变量的引用传递给方法(而不是变量的值)

mongodb - 使用数组过滤器更新失败