Mongodb sort()方法的size限制
阿新 • • 發佈:2018-12-06
問題描述
當我對一個沒有建索引的欄位做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的時候佔用更多的記憶體。