MondoDB/Mongoose查询响应太慢

问题描述 投票:0回答:3

我是 MongoDB/Mongoose 的新手,并且使用一个非常大的数据库(超过 25000 个文档)。我需要配置不同的查询:按字段、前 10 个文档、按 id。问题在于性能 - 服务器响应太慢(大约 10-15 秒)。 请告诉我如何配置才能使服务器响应快? 它仅取决于模式设置还是取决于其他因素,例如数据库连接参数或查询参数?

附注查询应按“地区”和“地点”进行。 感谢您的帮助!

这是架构:

const mongoose = require('mongoose');

const Schema = mongoose.Schema;

const houseSchema = new Schema({
  code: {
    type: String,
    required: false
  },
  name: {
    type: String,
    required: true
  },
  district: {
    type: String,
    required: true
  },
  locality: {
    type: String,
    required: false
  },
  recountDate: {
    type: Date,
    default: Date.now
  },
  eventDate: {
    type: Date,
    default: Date.now
  },
  events: {
    type: Array,
    default: []
  }
});

module.exports = mongoose.model('House', houseSchema);

连接参数:

mongoose.connect(
  `mongodb+srv://${process.env.MONGO_USER}:${process.env.MONGO_PASSWORD}@cluster0-vuauc.mongodb.net/${process.env.MONGO_DB}?retryWrites=true&w=majority`,
  {
    useNewUrlParser: true,
    useUnifiedTopology: true
  }
).then(() => {
  console.log('Connection to database established...')
  app.listen(5555);
}).catch(err => {
  console.log(err);
});

使用中继执行查询:

query {
  viewer {
    allPosts (first: 10) {
      edges {
        node {
          id
          code
          district
          locality
          recountDate
          eventDate
          events
        }
      }
    }
  }
}
javascript node.js mongodb express mongoose
3个回答
5
投票

MongoDB 执行查询的速度非常快。但这也取决于您如何编写查询。用于获取前 10 个文档并将其按降序排列到集合中的 _id。您需要在查询中使用

limit
sort

db.collectionName.find({}).limit(10).sort({_id:-1})

3
投票

确保不是连接问题。尝试从 MongoDB shell 运行查询

mongo mongodb+srv://${process.env.MONGO_USER}:${process.env.MONGO_PASSWORD}@cluster0-vuauc.mongodb.net/${process.env.MONGO_DB}?retryWrites=true&w=majority
db.collection.find({condition}).limit(10)

如果在 MongoDB shell 中,它的响应速度比 Mongoose 更快

使用纯 Javascript

BSON 序列化器
Node.js 驱动程序存在问题,从 BSON 序列化到 JSON 的速度非常慢。

尝试安装

bson-ext

bson-ext
模块是用
C++
编写的替代BSON解析器。它提供了更好的反序列化性能以及与纯 JavaScript 解析器类似或稍微更好的序列化性能。

https://mongodb.github.io/node-mongodb-native/3.5/installation-guide/installation-guide/#bson-ext-module


3
投票

您可以阅读查询优化这里

使用投影仅返回必要的数据当您只需要文档中的部分字段时,您可以 通过仅返回您需要的字段来获得更好的性能:

例如,如果在查询 posts 集合时,您只需要 时间戳、标题、作者和摘要字段,您将发出 以下命令:

db.posts.find( {}, { timestamp : 1 , title : 1 , author : 1 , abstract : 1} ).sort( { timestamp : -1 } ).limit(10)
© www.soinside.com 2019 - 2024. All rights reserved.