记一次mongo查询时间从大于30多秒优化到100ms的过程

本文记录了一次Mongo查询优化过程,从最初超过30秒的查询时间,通过建立组合索引、拆分大字段、代码逻辑优化、数据量减少及引入Redis缓存,最终将查询时间降低到100ms。通过分析查询语句、拆分字段并调整数据量,显著提升了查询效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最初的30多秒

在这里插入图片描述
一个前端调用后端服务接口由于时间太长(超过30s),最终被cancel。
这是一个总数据量为62W的,mongo表。但是其中有一个字段,值为list<Object>,且个数不少,平均8个。算是一个大字段。

在这里插入图片描述

逐步优化

mongo建立组合索引(技术方向)

因此查询字段为日期,类型,关键词组合查询,所以,在建立collection后,直接建立一个组合索引,然后再插入数据。

DBObject bson = new BasicDBObject
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Think_Higher

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值