1. 程式人生 > >Mongodb sort()方法的size限制

Mongodb sort()方法的size限制

問題描述

當我對一個沒有建索引的欄位做find,然後做sort的時候,可能觸發sort的size的32MB限制,例如:

db.getCollection('Hotel').find({"time_stamp":{"$lte":1485878400}}).sort({"time_stamp": -1})

錯誤如下:

Error: error: {
"$err" : "Executor error: Overflow sort stage buffered data usage of 33558548 bytes exceeds internal limit of 33554432 bytes",
"code" : 17144
}

兩種解決方法

  • 解決方法一:對需要排序的欄位建索引
db.stotal.ensureIndex({'type': -1})
  • 解決方法二:修改預設配置,把sort時可以用的記憶體設定大點:
db.adminCommand({setParameter:1, internalQueryExecMaxBlockingSortBytes:335544320})

這兩種解決方法各有利弊:

  • 方法一:增加了索引會導致資料寫入變慢,儲存佔用變多;
  • 方法二:不建索引修改預設配置,會導致sort的時候佔用更多的記憶體。