最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
MongoDB位置查询内存使用优化详解
时间:2022-06-29 10:32:26 编辑:袖梨 来源:一聚教程网
生产环境实例频繁 OOM ,调查发现主要由一些$near查询导致,查询类似如下,其中 latlng 字段建立了2d index。
{
"find" : "userData",
"filter" : {
"latlng" : {
"$near" : [
116.34642045073839,
39.87082232130999
],
"$maxDistance" : 0.9009009009009009
}
},
"ntoreturn" : 10000
}
官方解释是因为$near需要排序,实际上是从中心点,不断往外扩展,找出附近的点,所以$near cursor会缓存计算结果。MongoDB cursor 的默认超时时间是10分钟,所以如果10分钟内所有打开 cursor 缓存的内存总量超过总内存,就会出现 OOM 的情况。
针对上述问题,应用有如下2种方式优化内存使用
设置更小的 cursor timeout
启动时设置 mongod –setParameter cursorTimeoutMillis=60000,也可以放到配置文件
在线修改 db.runCommand({setParameter: 1, cursorTimeoutMillis: 60000})
find 时设置{singeBatch: true}选项,让 mongod在查询后立即关闭 cursor,这种方法只适用于不需要对 cursor 进行 getMore 查询的情况。
相关文章
- 美国财政部取消加密货币经纪人报告规定 - 详情 07-13
- dreamweaver网页上怎么制作DI5图层? 07-13
- 村上春树经典语录大全81句 07-13
- 燕云十六声真假卧佛任务怎么完成-真假卧佛任务攻略 07-13
- ps怎么处理高低肩? ps照片人物高低肩的调整办法 07-13
- LoginPress PRO v5.0.1 汉化版 自定义WordPress 注册与登录 07-13