猫鼬将无法连接到Mlab

时间:2019-12-18 21:21:35

标签: node.js mongodb express mongoose

我正在尝试从节点应用程序连接到mlab数据库,而当我尝试连接时它只是挂起。即使我的mlab数据库使用其他端口,它也会显示错误中的默认端口27017。

我在其他项目上使用过mlab和mongoose,但从未收到此错误,所以非常困惑。

错误:

{ MongoTimeoutError: Server selection timed out after 30000 ms
    at Timeout.setTimeout [as _onTimeout] (/Users/<user>/playground/mongo-test/node_modules/mongodb/lib/core/sdam/server_selection.js:308:9)
    at ontimeout (timers.js:475:11)
    at tryOnTimeout (timers.js:310:5)
    at Timer.listOnTimeout (timers.js:270:5)
  name: 'MongoTimeoutError',
  reason:
   { Error: getaddrinfo ENOTFOUND <my username> <my username>:27017
    at errnoException (dns.js:50:10)
    at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:92:26)
     name: 'MongoNetworkError',
     [Symbol(mongoErrorContextSymbol)]: {} },
  [Symbol(mongoErrorContextSymbol)]: {} }

我的代码:

const express = require('express');
const app = express();
const mongoose = require('mongoose');

const PORT = process.env.PORT || 8000;

mongoose.connect('mongodb://<my username>:<my password>@<theservername>.mlab.com:59577/express-chat-dev', { useNewUrlParser: true, useUnifiedTopology: true }, (err) => {
    console.log('[hello]');
    if (err) {
        console.error(err);
    } else {
        console.log('[mongo connected]');
    }
});

app.listen(PORT, () => {
    console.log(`Express running on port ${PORT}`)
})

1 个答案:

答案 0 :(得分:0)

所以我不确定这是否是API更改,但是将我的凭据移到options对象中解决了我的问题。

const express = require('express');
const app = express();
const mongoose = require('mongoose');

const PORT = process.env.PORT || 8000;

const options = {
  user: <username>, 
  pass: <password>, 
  useNewUrlParser: true, 
  useUnifiedTopology: true
}

mongoose.connect('mongodb://<theservername>.mlab.com:59577/express-chat-dev', options, (err) => {
    console.log('[hello]');
    if (err) {
        console.error(err);
    } else {
        console.log('[mongo connected]');
    }
});

app.listen(PORT, () => {
    console.log(`Express running on port ${PORT}`)
})