无法将 Node.js 应用程序与 MongoDB Atlas 连接

时间:2021-07-26 10:10:10

标签: node.js mongodb express mongoose mongodb-atlas

我在 MongoDB Atlas 中创建了一个新集群,但我无法将我的 node.js 应用与它连接。我是后端新手,正在学习 MongoDB。

Error: querySrv ENODATA _mongodb._tcp.cluster0.onw2w.mongodb.net
at QueryReqWrap.onresolve [as oncomplete] (dns.js:206:19) {
    errno: undefined,
    code: 'ENODATA',
    syscall: 'querySrv',
    hostname: '_mongodb._tcp.cluster0.onw2w.mongodb.net'
}

服务器运行成功。在连接到 Atlas 之前,我的应用程序正在运行。我再次从头创建了一个新集群,以便确保我在创建集群时没有出错。

server.js 文件

const mongoose = require('mongoose');
const dotenv = require('dotenv');
const app = require('./app');
dotenv.config({ path: './config.env' });

const DB = process.env.DATABASE.replace(
  '<PASSWORD>',
  process.env.DATABASE_PASSWORD
);

mongoose
  .connect(DB, {
    useNewUrlParser: true,
    useCreateIndex: true,
    useFindAndModify: false,
    useUnifiedTopology: true,
  })
  .then((con) => console.log('DB connection successful?....'))
  .catch((error) => console.log(error));

const tourSchema = new mongoose.Schema({
  // to specify a schema for our model
  name: {
    type: String,
    require: [true, 'A tour must have a name'], // validator
    unique: true,
  },
  rating: {
    type: Number,
    require: 4.5,
  },
  price: {
    type: Number,
    require: [true, 'A tour must have a price'],
  },
});

const Tour = mongoose.model('Tour', tourSchema);

const testTour = new Tour({
  // it is an instance of the tour model
  name: 'The forest Hiker',
  rating: 4.7,
  price: 497,
});

testTour
  .save() // this will save the data in the Tour collection in the database it will return a promise
  .then(doc => console.log(doc))
  .catch(err=> console.log('error: ', err))

const port = process.env.PORT || 8000;
app.listen(port, '127.0.0.1', () => {
  console.log(`server running on port ${port}?.......`);
});

.env 文件

NODE_ENV=devlopment
PORT=8000
USERNMAE=IrfanAsif
DATABASE_PASSWORD=zAC8yIHLJIegJHSQ
DATABASE=mongodb+srv://irfan:<PASSWORD>@cluster0.onw2w.mongodb.net/myFirstDatabase?retryWrites=true&w=majority

1 个答案:

答案 0 :(得分:0)

所以首先,我没有看到将密码保留在数据库连接字符串之外的任何特殊原因,因为它位于 .env 变量中,因此最终用户或没有密码的任何人都不会使用它访问服务器文件。

对于您的问题,您能否将 proccess.env.DATABASE 和密码记录到控制台,以确保它正确打印出来?由于您的回调和承诺解析似乎没问题,应该是配置问题。