我需要帮助!!!我尝试使用连接字符串连接到mongodb地图集,但无法连接。我不确定如何进行。我有准系统的申请。我收到连接错误(mongooseServerSelectionError)和未处理的Promise Rejection警告。
这是错误:
connection error: MongooseError [MongooseServerSelectionError]: connect ECONNREFUSED 127.0.0.1:27017
at new MongooseServerSelectionError (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/error/serverSelection.js:22:11)
at NativeConnection.Connection.openUri (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/connection.js:808:32)
at Mongoose.connect (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/index.js:333:15)
at Object.<anonymous> (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/server/db/index.js:4:10)
at Module._compile (internal/modules/cjs/loader.js:1157:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1177:10)
at Module.load (internal/modules/cjs/loader.js:1001:32)
at Function.Module._load (internal/modules/cjs/loader.js:900:14)
at Module.require (internal/modules/cjs/loader.js:1043:19)
at require (internal/modules/cjs/helpers.js:77:18)
at Object.<anonymous> (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/server/bin.js:33:10)
at Module._compile (internal/modules/cjs/loader.js:1157:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1177:10)
at Module.load (internal/modules/cjs/loader.js:1001:32)
at Function.Module._load (internal/modules/cjs/loader.js:900:14)
at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:74:12) {
message: 'connect ECONNREFUSED 127.0.0.1:27017',
name: 'MongooseServerSelectionError',
reason: TopologyDescription {
type: 'Single',
setName: null,
maxSetVersion: null,
maxElectionId: null,
servers: Map { 'localhost:27017' => [ServerDescription] },
stale: false,
compatible: true,
compatibilityError: null,
logicalSessionTimeoutMinutes: null,
heartbeatFrequencyMS: 10000,
localThresholdMS: 15,
commonWireVersion: null
},
[Symbol(mongoErrorContextSymbol)]: {}
}
(node:9182) UnhandledPromiseRejectionWarning: MongooseServerSelectionError: connect ECONNREFUSED 127.0.0.1:27017
at new MongooseServerSelectionError (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/error/serverSelection.js:22:11)
at NativeConnection.Connection.openUri (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/connection.js:808:32)
at Mongoose.connect (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/node_modules/mongoose/lib/index.js:333:15)
at Object.<anonymous> (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/server/db/index.js:4:10)
at Module._compile (internal/modules/cjs/loader.js:1157:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1177:10)
at Module.load (internal/modules/cjs/loader.js:1001:32)
at Function.Module._load (internal/modules/cjs/loader.js:900:14)
at Module.require (internal/modules/cjs/loader.js:1043:19)
at require (internal/modules/cjs/helpers.js:77:18)
at Object.<anonymous> (/Users/jagnoorg/Documents/personal-projects/monkey-den/project2/server/bin.js:33:10)
at Module._compile (internal/modules/cjs/loader.js:1157:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1177:10)
at Module.load (internal/modules/cjs/loader.js:1001:32)
at Function.Module._load (internal/modules/cjs/loader.js:900:14)
at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:74:12)
(node:9182) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). To terminate the node process on unhandled promise rejection, use the CLI flag `--unhandled-rejections=strict` (see https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode). (rejection id: 1)
(node:9182) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
这是我的代码:
我给出了连接uri的方向,通过猫鼬建立连接,导出数据库并在 app.js ...
中打开连接在 db / index.js 内部:
var mongoose = require('mongoose');
mongoose.Promise = global.Promise;
// const uri = require('../../keys.js').mongodb.dbURI;
mongoose.connect("mongodb://localhost/test", { useNewUrlParser: true, useUnifiedTopology: true});
// mongoose.connect(process.env.MONGODB_URL || uri, { useNewUrlParser: true, useUnifiedTopology: true});
var db = mongoose.connection;
db.on("error", console.error.bind(console, "connection error: "));
module.exports = db;
内部 app.js :
console.log('NODE_ENV :::', process.env.NODE_ENV);
if (process.env.NODE_ENV === 'PRODUCTION') {
var app = require('./prod.app.js');
} else {
var app = require('./dev.app.js');
}
var express = require('express');
var path = require('path');
var routes = require('./db/routes/index.js');
var http = require('http');
var favicon = require('serve-favicon');
var PORT = 3000;
/*
* shared code in production and development
*/
// favicon - 3 ways - middleware, static, html
app.use(favicon(path.join(__dirname, '../public/images/favicon.ico')));
// app.use('/favicon.ico', express.static(path.join(__dirname, '../public/images/favicon.ico')));
// app.use('images/favicon.ico', express.static(path.join(__dirname, '../public/images/favicon.ico')));
app.use(express.json());
app.use(express.urlencoded({ extended: true}));
// static files
app.use(express.static(path.join(__dirname, "../client")));
app.use(express.static(path.join(__dirname, "../public")));
// db - mongo
var db = require('./db/index.js');
db.once("open", function (err) {
// console.log('db::: ', db);
if (err) {
return console.error(err);
} else {
console.log("Successfully connected to mongodb");
}
})
// routes
app.use(routes);
// serve index.html if can't find the route
app.use('*', function (req, res, next) {
console.log("...serving index.html file from the public folder")
res.sendFile(path.join(__dirname, '../public/index.html'));
});
// create server
var server = http.createServer(app);
server.listen(PORT);
console.log(`server listening on post ${PORT}`);
谢谢你为我研究这个
答案 0 :(得分:7)
您的app.js app.use(cors())
中有此行吗?
尝试删除此行并删除涉及cors的所有内容。
如果这不起作用,请在MongoDB Atlas中的“网络访问”中检查IP白名单,并添加当前IP或将此0.0.0.0/0写入以允许所有IP。
答案 1 :(得分:4)
检查您的IP是否已由mongodb地图集启用。 您应该从mongodb地图集访问您的计算机IP地址。 转到网络访问权限(左侧栏),输入IP或输入0.0.0.0以访问所有IP。
答案 2 :(得分:2)
在Connection ip地址的mongoDB ATLAS中将当前IP地址设置为0.0.0.0/0。它将允许连接所有IP地址。
答案 3 :(得分:1)
尝试添加Atlas提供的网址以连接您的应用程序
mongoose.connect("<URLprovidedByAtlas>", { useNewUrlParser: true, useUnifiedTopology: true});
答案 4 :(得分:1)
bro更新mongodb atlus中的(ip)地址。它将帮助您
答案 5 :(得分:1)
尝试检查您的互联网连接以及IP地址是否正确。
https://github.com/Automattic/mongoose/issues/8180#issuecomment-552161146
答案 6 :(得分:1)
这对我有用。我首先将IP地址更改为0.0.0.0/0,并删除了app.use(cores())。然后,我下载了mongoDB罗盘,并连接到数据库。之后,在index.js中使用相同的URI。在URI和指南针中输入密码有所不同。在罗盘中,您无需对密码进行编码(如果您有特殊字符)。如果使用指南针进行连接并将该链接粘贴到index.js中,则无需对密码进行编码。
答案 7 :(得分:0)
通过以下方法检查是否已在终端中启动数据库 ./mongod