MONGODB 2.6.8 的一個BUG [Assertion: 13548:BufBuilder attempted to grow() to 134217728 bytes, past the ]

來源:互聯網
上載者:User

環境:mongoDB2.6.8 叢集,
下午突然發現4個從節點,掛了3個,全都都出現以下提示:

2016-03-11T16:53:02.483+0800 [conn312773] Assertion: 13548:BufBuilder attempted to grow() to 134217728 bytes, past the 64MB limit.

經分析, [conn312773] 串連前面的查詢 全是統計分析類的查詢,後跟開發部確認。
他們自己認為是以下查詢 有問題。

這裡不太常用到的是:  item:{$push:"$$ROOT"}
這個功能是這樣的: 查詢 到的資料,把所有的資料明細表用$push 方式到item 再返回,
這樣處理好處是在一個頁面中,前面有摘要資料,後面還有對應的明細。
但缺點是如果明細值太大,那麼就觸發了上面的BUG.在官方BUG說明中是說在版本2.4.6就已解決了。但在2.6.8我們還
是遇到,也有可能很少這樣用的原因吧。


db.getCollection('PInfo').aggregate([
   {
        $match:{MID:86}
   },
   {
      $group : {
          _id : { PID : "$PID"},
          sumcount : { $sum : 1 },
          item:{$push:"$$ROOT"}
      }
   }
])


我們的解決方案:
把item 中$push 的值從總條記錄,修改到只返回某幾個欄位(盡量少,同時不要返回子文檔及數組,因為這兩種類型很難預見有多大)
再把查詢條件最佳化成最小,每次只查詢少量資料。從而減少返回的資料量。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.