婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MongoDB數據庫查詢性能提高40倍的經歷分享

MongoDB數據庫查詢性能提高40倍的經歷分享

熱門標簽:怎么投訴地圖標注 云南外呼系統 廣州長安公司怎樣申請400電話 呼和浩特電銷外呼系統加盟 蘋果汽車租賃店地圖標注 濟南電銷機器人加盟公司 老虎洗衣店地圖標注 電銷機器人是什么軟件 杭州人工電銷機器人價格

前言

數據庫性能對軟件整體性能有著至關重要的影響,本文給大家分享了一次MongoDB數據庫查詢性能提高40倍的經歷,感興趣的朋友們可以參考學習。

背景說明

1、數據庫:MongoDB

2、數據集:

  • A:字段數不定,這里主要用到的兩個UID和Date
  • B:三個字段,UID、Date、Actions。其中Actions字段是包含260元素JSON數組,每個JSON對象有6個字段。共有數據800萬條左右。

3、業務場景:求平均數

  • 通過組合條件從A數據表查詢出(UID,Date)列表,最多可能包含數萬條記錄;
  • 然后用第1步的結果從B中查詢出對應的數據
  • 用第2步結果去Actions的某個固定位置的元素的進行計算

進化過程

在這里使用Python演示

最直接想到的方法

根據上面的業務場景描述,最容易想到的解決方法就是

from pymongo import MongoClient
# 連接數據庫
db = MongoClient('mongodb://127.0.0.1:27017')['my_db']

# 簡化的查詢數據集A的條件
filter = {...}
# 查詢Collection A
a_cursor = db.a.find(_filter)
a_docs = [x for x in a_cursor]

# 變量的初始定義
count = 0
total = 0
# 加入需要用到的元素為第21個
index = 20
# 查詢Collection B,同時做累加
for a_doc in a _docs:
 b_doc = db.b.find_one({'uid':a_doc['uid'], 'date': a_doc['date']})
 # 只有能查到相應的結果時,才可以
 if b_doc is not None:
 total += b_doc['actions'][20]['number']
 count += 1

 # 求平均數
 if count > 0 :
 avg = total/count

實現難度當然是最低的,可是整個任務在第一步只有1萬條左右的返回時,消耗的時間竟然達到了驚人38秒。當然這是已經加了索引的結果,否則可能都無法得到結果了。

減少查詢次數

瓶頸顯而易見,在循環中查詢Collection B,增加了網絡開銷,自然也就增加時間,如果一次查詢出所有結果,自然會大大提高效率。也就是說,我要把第一步的結果作為條件一次性傳遞,做一個$in操作。可是怎么才能做到呢?如果在uid和date上分別做$in操作,那么返回的結果就會是二者單獨做$操作的合集,很顯然這和要求是不符的。

經過上面的分析,似乎進入了死胡同。其實答案也基本顯現了,需要有一個字段可以滿足上面的要求,那么這個字段就是uid和date的合體,就命名為uid_date。uid_date是一個新字段,在B中并不存在,在使用之前需要將數據庫現有的數據做一下處理。

處理完畢改造程序:

# 下面的只體現和本次修改相關的內容
uid_date_list = []
for a_doc in a_docs:
 uid_date_list.append(a_doc['uid'] + '_' + a_doc['date'])

# 查詢B
b_cursor = db.b.find({'uid_date':{'$in':uid_date_list}})

# 下面就是取出結果,求平均數
...

這一番改造頗費時間,主要是前期的數據處理。代碼改造完畢,執行下看看吧。

可是,可是…… 45秒

我做錯了什么?!

增加返回記錄數

我還是堅信上面的優化思路是對的,現在看看數據庫能給一些什么線索吧。

登錄到數據庫服務器,找到MongoDB的日志/data/mongodb/logs/mongod.log。仔細查找,發現在查詢數據集B時有很多getMore命令。這就奇怪了,我是一次性查詢,為什么還有getMore。

趕緊查下官方的文檔,然后發現了下面的內容:


batcSize參數指定了每次返回的個數,默認的101個。那看來這個應該是問題所在。找下pymongo的文檔,也可以設置這個參數,那就設個大的吧10000。

再次改造程序如下:

# 增加batch_size
b_cursor = db.b.find({'uid_date':{'$in': uid_date_list}}, batch_size=10000)

這次總該可以了。

嗯,好了一些,降到了20秒左右。可是,這離1秒只能還差距20倍呢。

返回值減負

當日不能放棄,繼續通過日志查找線索,發現還是有很多getMore。通過各方查找,發現mongodb每次最多返回16M的記錄,通過getMore日志的比對,發現的確如此。由于B中每條記錄的過去龐大,每次只能幾百條記錄,因此要一次多返回,那就必須要減少每次返回的記錄數。因為在計算時,只用了特定索引位置上的數據,所以只返回該條記錄就可以了。

最后的代碼就不再寫了,具體可以參考官方文檔的實例。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

您可能感興趣的文章:
  • 記一次MongoDB性能問題(從MySQL遷移到MongoDB)
  • 淺析Mongodb性能優化的相關問題
  • MongoDB性能篇之創建索引,組合索引,唯一索引,刪除索引和explain執行計劃
  • MongoDB查詢性能優化驗證及驗證
  • MongoDB性能優化及監控
  • 提升MongoDB性能的方法

標簽:遼陽 泰安 廈門 無錫 自貢 玉林 興安盟 雞西

巨人網絡通訊聲明:本文標題《MongoDB數據庫查詢性能提高40倍的經歷分享》,本文關鍵詞  MongoDB,數據庫,查詢,性能,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MongoDB數據庫查詢性能提高40倍的經歷分享》相關的同類信息!
  • 本頁收集關于MongoDB數據庫查詢性能提高40倍的經歷分享的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品乡下勾搭老头1| 国产福利一区二区三区视频在线 | 91激情在线视频| 亚洲日本丝袜连裤袜办公室| 国产成人在线观看免费网站| 亚洲成人综合网站| 精品久久久影院| 色婷婷香蕉在线一区二区| 日韩电影在线免费观看| 亚洲日本成人在线观看| 欧美日韩不卡视频| 亚洲一区二区三区四区的| 日韩一级大片在线| 欧美三级视频在线观看 | 日韩午夜激情电影| 在线观看视频欧美| 国产91精品一区二区| 久久激情综合网| 国内精品视频666| 婷婷六月综合亚洲| 亚洲一二三区不卡| 国产欧美日韩精品a在线观看| 欧美日韩精品专区| 亚洲午夜成aⅴ人片| 亚洲日本青草视频在线怡红院| 欧美综合视频在线观看| 国产91精品久久久久久久网曝门| 日本亚洲一区二区| 夜夜嗨av一区二区三区中文字幕| 国产欧美精品一区二区色综合朱莉| 欧美高清视频一二三区| 日韩欧美一区二区三区在线| 2021久久国产精品不只是精品| 久久影音资源网| 中文字幕一区二区三区av| 久久久精品人体av艺术| 国产精品不卡一区| 中文字幕字幕中文在线中不卡视频| 久久久亚洲精品石原莉奈| 综合电影一区二区三区| 亚洲精品网站在线观看| 国产盗摄精品一区二区三区在线| 国产丶欧美丶日本不卡视频| 欧美图片一区二区三区| 日韩一二三四区| 亚洲一二三级电影| 成人永久免费视频| 欧美电影在线免费观看| 精品日本一线二线三线不卡| 樱花草国产18久久久久| 久久不见久久见中文字幕免费| 五月婷婷激情综合| 精品一区二区久久| 国产夜色精品一区二区av| 亚洲精品欧美综合四区| 国产一区三区三区| 在线观看区一区二| 国产网站一区二区| 精久久久久久久久久久| 精品视频1区2区| 国产精品色在线观看| 国产成人夜色高潮福利影视| 91同城在线观看| 综合久久给合久久狠狠狠97色 | 国产日产欧美精品一区二区三区| 午夜精品久久久久久久99水蜜桃| 国产mv日韩mv欧美| 久久―日本道色综合久久| 日韩综合小视频| 欧美午夜不卡视频| 日本视频免费一区| 日韩午夜激情av| 久久99国产乱子伦精品免费| 欧美sm美女调教| 国产成人av电影| 欧美日韩精品久久久| 国产色综合一区| 午夜电影一区二区| 91麻豆精品国产91久久久久久 | 国产亚洲一区二区三区四区 | 亚洲视频网在线直播| 色呦呦国产精品| 日本欧美大码aⅴ在线播放| 国产欧美一区二区精品久导航| 国产a久久麻豆| 天天综合天天综合色| 欧美日韩五月天| 国产丶欧美丶日本不卡视频| 亚洲电影一级片| 欧美电影免费观看高清完整版在 | 精品少妇一区二区三区日产乱码 | 亚洲日本va午夜在线影院| 久久嫩草精品久久久精品一| 国产午夜亚洲精品理论片色戒| 久久伊人蜜桃av一区二区| 国产午夜精品福利| 中文字幕一区二区不卡 | 国产精品免费久久| 国产精品伦一区| 亚洲免费伊人电影| 亚洲成人免费视| 另类小说视频一区二区| 国产一区二区主播在线| 91在线视频18| 久久久一区二区三区| 中文字幕在线观看不卡视频| 亚洲成av人片在线观看| 中文字幕av一区二区三区免费看 | 在线观看日韩电影| 欧美日韩aaaaaa| 91看片淫黄大片一级在线观看| 久久99精品久久久久| 日韩国产一区二| 一色屋精品亚洲香蕉网站| 欧美久久久久久久久| 夜夜嗨av一区二区三区网页 | 精品国产亚洲在线| 欧美国产一区视频在线观看| 国产精品网曝门| 日本美女一区二区三区视频| 国内外精品视频| 91国产成人在线| 欧美成人伊人久久综合网| 中文字幕日韩一区二区| 国产综合色在线视频区| 色综合久久久网| 日韩免费视频线观看| 亚洲午夜视频在线| 精品一区二区三区在线播放| 欧美男同性恋视频网站| 国产精品国产精品国产专区不蜜| 欧美国产一区在线| 亚洲综合在线电影| 欧美日韩在线精品一区二区三区激情 | 欧美人伦禁忌dvd放荡欲情| 国产精品麻豆网站| 九九九精品视频| 欧美一区二区三区免费观看视频 | 国产精品女同互慰在线看| 日本欧美一区二区三区乱码| 欧美在线你懂得| 国产精品欧美久久久久一区二区| 欧美日韩综合一区| 91精品一区二区三区久久久久久 | 欧洲精品视频在线观看| 精品国产一区二区三区忘忧草 | 亚洲综合偷拍欧美一区色| 成人av小说网| 亚洲精品一二三四区| 制服.丝袜.亚洲.中文.综合| 成人黄色777网| 日本中文在线一区| 久久久久久久久久久黄色| 国产成人免费视频网站 | 国产精品色哟哟| 欧美高清你懂得| 91精品国产综合久久福利| 欧美精品一区二区三区蜜臀| 久久精品国产免费| 国产精品日韩精品欧美在线| 国产精品一二三四五| 亚洲国产综合在线| 欧美性猛交xxxx乱大交退制版| 精品三级在线看| 午夜精品视频在线观看| 免费xxxx性欧美18vr| 亚洲国产一区在线观看| 偷拍自拍另类欧美| 久久精品亚洲国产奇米99| 91麻豆国产福利精品| 日本中文字幕一区二区有限公司| 精品88久久久久88久久久| 欧美另类变人与禽xxxxx| 成人动漫精品一区二区| 国产河南妇女毛片精品久久久 | 亚洲女子a中天字幕| 国产精品午夜免费| 中文字幕乱码日本亚洲一区二区 | 欧美日韩一区二区三区不卡 | 国产精品99久久久久| 精品一区二区三区视频 | 91成人免费在线| 国产精品99久久久久久宅男| 国产精品二三区| 中文字幕在线观看一区| 狠狠v欧美v日韩v亚洲ⅴ| 成人免费视频免费观看| 国产精品欧美精品| 亚洲色欲色欲www在线观看| 成人av在线观| 亚洲国产一区视频| 激情偷乱视频一区二区三区| 在线不卡中文字幕播放| 亚洲精品高清在线观看| 在线播放91灌醉迷j高跟美女| 久久综合久色欧美综合狠狠| 91老司机福利 在线| 亚洲欧美综合另类在线卡通| 91精品国产综合久久久久久久| 日韩女同互慰一区二区|