我是 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
}
}
}
}
}
MongoDB 执行查询的速度非常快。但这也取决于您如何编写查询。用于获取前 10 个文档并将其按降序排列到集合中的 _id。您需要在查询中使用
limit
和 sort
。
db.collectionName.find({}).limit(10).sort({_id:-1})
确保不是连接问题。尝试从 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
编写的替代BSON解析器。它提供了更好的反序列化性能以及与纯 JavaScript 解析器类似或稍微更好的序列化性能。C++
您可以阅读查询优化这里
使用投影仅返回必要的数据当您只需要文档中的部分字段时,您可以 通过仅返回您需要的字段来获得更好的性能:
例如,如果在查询 posts 集合时,您只需要 时间戳、标题、作者和摘要字段,您将发出 以下命令:
db.posts.find( {}, { timestamp : 1 , title : 1 , author : 1 , abstract : 1} ).sort( { timestamp : -1 } ).limit(10)