博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MongoDB位置查询内存使用优化
阅读量:6495 次
发布时间:2019-06-24

本文共 707 字,大约阅读时间需要 2 分钟。

生产环境实例频繁 OOM ,调查发现主要由一些$near查询导致,查询类似如下,其中 latlng 字段建立了。

{    "find" : "userData",    "filter" : {        "latlng" : {            "$near" : [                116.34642045073839,                39.87082232130999            ],            "$maxDistance" : 0.9009009009009009        }    },    "ntoreturn" : 10000}

官方解释是因为$near需要排序,实际上是从中心点,不断往外扩展,找出附近的点,所以$near cursor会缓存计算结果。MongoDB cursor 的默认超时时间是10分钟,所以如果10分钟内所有打开 cursor 缓存的内存总量超过总内存,就会出现 OOM 的情况。

针对上述问题,应用有如下2种方式优化内存使用

  1. 设置更小的 cursor timeout

    • 启动时设置 mongod --setParameter cursorTimeoutMillis=60000,也可以放到配置文件
    • 在线修改 db.runCommand({setParameter: 1, cursorTimeoutMillis: 60000})
  2. find 时设置选项,让 mongod在查询后立即关闭 cursor,这种方法只适用于不需要对 cursor 进行 getMore 查询的情况。

了解问题详细情况可以查看

转载地址:http://gpyyo.baihongyu.com/

你可能感兴趣的文章
Eclipse中设置在创建新类时自动生成注释
查看>>
我的友情链接
查看>>
CoreOS 手动更新
查看>>
golang 分页
查看>>
再论机械式针对接口编程
查看>>
25 个 Linux 性能监控工具
查看>>
C#程序员整理的Unity 3D笔记(十三):Unity 3D基于组件的思想
查看>>
Tengine-2.1.1 ngx_http_concat_module 400问题
查看>>
Windows中挂载安装ISO文件
查看>>
Wayland 1.0发布
查看>>
golang的goroutine是如何实现的?
查看>>
乐视云基于Kubernetes的PaaS平台建设
查看>>
R 学习笔记《十》 R语言初学者指南--图形工具
查看>>
PHP通过读取DOM抓取信息
查看>>
DICOM医学图像处理:DICOM网络传输
查看>>
nio和传统Io的区别
查看>>
移动端网页布局中需要注意事项以及解决方法总结
查看>>
(原创)Linux下查看系统版本号信息的方法
查看>>
oracle
查看>>
redis使用过程中主机内核层面的一些优化
查看>>