亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

mongodb查詢耗時的方法是什么?

2024-09-07 00:22:26
字體:
來源:轉載
供稿:網友
       文本主要給大家介紹的是關于MongoDB查詢耗時的方法,小編覺得比較實用,因此分享給大家作參考,需要的朋友可以參考參考,下面就跟隨小編一起看看吧。
 
       準備
 
       在此之前,我們先在我們的數據庫中插入10萬條數據。數據的格式是這樣的:
 
{
 "name":"your name",
 "age":22,
 "gender":"male",
 "grade":2
}
       explain
 
       explain方法是用來查看db.collecion.find()的一些查詢信息的。例如:
 
db.collectionName.find().explain()
       explain方法有個可選的參數verbose,是個字符串,他表示的是verbose的模式。一共分為3種模式:
 
       queryPlanner:默認參數,詳細說明查詢優化器選擇的計劃并列出被拒絕的計劃。例如:
db.students.find({grade:1}).explain()
 
 
       executionStats:MongoDB運行查詢優化器選擇獲勝的計劃,執行計劃,完成并返回成功,統計描述的勝利計劃的執行。例如:
db.students.find({grade:1}).explain("executionStats")
 
       allPlansExecution:MongoDB返回描述獲獎計劃的執行以及對其他候選人統計計劃選擇方案時捕獲的統計。
       我們的目的是要記錄執行find方法的耗時時間,所以用executionStats模式就可以了。
 
       返回的結果也是只關注executionStats就可以了,如下圖:
 
 
nReturned:表示該查詢條件下返回的文檔數量。
executionTimeMills:表示執行時間,單位毫秒
totalDocsExamined:表示該集合總共文檔數。
       其他的屬性在這里就不多說了,記錄耗時我們只取executionTimeMills.
 
       Profiling
 
       上面提到的方法好像是只適用find方法,對于一些聚合查詢之類的查詢方法就無法統計耗時時間了。這里再介紹一個profiling方法記錄查詢耗時時間。
 
       開啟 Profiling 功能
 
       有兩種方式可以控制 Profiling 的開關和級別,第一種是直接在啟動參數里直接進行設置。
啟動MongoDB時加上-Cprofile=級別 即可。
也可以在客戶端調用db.setProfilingLevel(級別)命令來實時配置??梢酝ㄟ^db.getProfilingLevel()命令來獲取當前的Profile級別。
       例如:
 
db.setProfilingLevel(2)
db.getProfilingLevel()
 
 
       Profiling一共分為3個級別:
0 - 不開啟。
1 - 記錄慢命令 (默認為>100ms)
3 - 記錄所有命令
       Profile 記錄在級別1時會記錄慢命令,那么這個慢的定義是什么?上面我們說到其默認為100ms,當然有默認就有設置,其設置方法和級別一樣有兩種,一種是通過添 加-Cslowms啟動參數配置。第二種是調用db.setProfilingLevel時加上第二個參數:
 
db.setProfilingLevel( level , slowms)
db.setProfilingLevel( 1 , 10 );
       查詢 Profiling 記錄
 
       開啟profiling功能后,系統會把相關命令詳細信息記錄到當前數據庫的system.profile集合里。查詢方法也是跟普通的集合查詢一樣。
 
db.system.profile.find()
 
 
       其中,mills就是命令耗時記錄。
       由于我們設置的級別是2,所以所有命令都有記錄,現在我們把他改為級別1,且只記錄耗時20毫秒以上的記錄:
 
 db.setProfilingLevel( 1 , 20)
 
 
       然后我們再執行一下聚合查詢,查看下耗時時間:
 
db.students.aggregate( {$group:{_id:"$grade",avgAge:{$avg:"$age"}}} )
 
 
db.system.profile.find().pretty()
 
       可以看出,我們的這聚合查詢耗時70毫秒。
 
       profile 部分字段解釋
 
op:操作類型
ns:被查的集合
commond:命令的內容
docsExamined:掃描文檔數
nreturned:返回記錄數
millis:耗時時間,單位毫秒
ts:命令執行時間
responseLength:返回內容長度
       下面介紹幾個常用的查詢命令:
 
       列出執行時間長于某一限度(例如:20ms)的 Profile 記錄.
db.system.profile.find({millis:{$gt:50}})
 
 
       查看最新的 3條Profile 記錄:
db.system.profile.find().sort({$natural:-1}).limit(3)
 
 
       查看關于某個collection的相關慢查詢操作:
db.system.profile.find({ns:'mydb.students'})
       MongoDB 查詢優化
 
  docsExamined(掃描的記錄數)遠大于nreturned(返回結果的記錄數)的話,那么我們就要考慮通過加索引來優化記錄定位了。
  responseLength 如果過大,那么說明我們返回的結果集太大了,這時請查看find函數的第二個參數是否只寫上了你需要的屬性名。(類似 于MySQL中不要總是select)
  對于創建索引的建議是:如果很少讀,那么盡量不要添加索引,因為索引越多,寫操作會越慢。如果讀量很大,那么創建索引還是比較劃算的。
 
       Profiler 的效率
 
  Profiling 功能肯定是會影響效率的,但是不太嚴重,原因是他使用的是system.profile 來記錄,而system.profile 是一個capped collection 這種collection 在操作上有一些限制和特點,但是效率更高。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品国产欧美一区二区五十路| 亚洲欧美日韩国产精品| 日韩av一卡二卡| 日韩成人黄色av| 最近2019年中文视频免费在线观看| 亚洲国产日韩欧美在线动漫| 国产精品久久久av久久久| 亚洲福利在线视频| 亚洲九九九在线观看| 亚洲女同精品视频| 日韩一区二区三区在线播放| 精品久久久91| 精品国产一区二区三区久久久狼| 亚洲人成网在线播放| 91av在线免费观看视频| 国产在线观看精品一区二区三区| 日韩电影中文字幕在线观看| 国产成人一区二区三区电影| 亚洲系列中文字幕| 中文字幕在线观看亚洲| 91精品在线国产| 精品国产乱码久久久久久天美| 亚洲影影院av| 亚洲精品久久久久中文字幕欢迎你| 欧美精品在线网站| 91美女福利视频高清| 丰满岳妇乱一区二区三区| 久久婷婷国产麻豆91天堂| 国产精品入口日韩视频大尺度| 国内精品久久久久久久久| 日韩av资源在线播放| 亚洲国产另类久久精品| 中文字幕亚洲综合久久| 久久久国产精品一区| 久久成人18免费网站| 97不卡在线视频| 欧美在线一级va免费观看| 日韩av在线网站| 国产成+人+综合+亚洲欧洲| 久久久免费电影| 一区三区二区视频| 久久久免费av| 国内伊人久久久久久网站视频| 不用播放器成人网| 欧美亚洲国产精品| 亚洲福利视频网| 5278欧美一区二区三区| 欧美中文字幕在线视频| 国产色综合天天综合网| 亚洲免费中文字幕| 欧美日韩国产在线播放| 久久久久久久电影一区| 国产精品久久久久77777| 欧美激情一区二区三区久久久| 国产精品视频专区| 高潮白浆女日韩av免费看| 日韩av在线网站| 一本色道久久88综合日韩精品| 欧美视频第一页| 国产日韩欧美在线视频观看| 亚洲 日韩 国产第一| 疯狂蹂躏欧美一区二区精品| 欧美高跟鞋交xxxxhd| 欧美重口另类videos人妖| 久久久av亚洲男天堂| 精品国产精品三级精品av网址| 日韩高清电影好看的电视剧电影| 久久国产精品久久精品| 日韩欧美有码在线| 亚洲人精品午夜在线观看| 最近中文字幕2019免费| 久久艹在线视频| 欧美www视频在线观看| 秋霞av国产精品一区| 亚洲美女在线视频| 国产欧美一区二区三区四区| 国产视频在线观看一区二区| 亚洲国产一区自拍| 青青草99啪国产免费| 亚洲午夜性刺激影院| 亚洲精品视频播放| 中文字幕国产亚洲2019| 久久高清视频免费| 一区二区三区视频免费在线观看| 精品中文字幕在线| 国产精品成人免费电影| 免费av在线一区| 狠狠躁夜夜躁人人躁婷婷91| 韩国19禁主播vip福利视频| 亚洲午夜未删减在线观看| 欧美日韩成人在线观看| 久久视频在线看| 欧美性在线观看| 日韩一区二区在线视频| 国产亚洲精品久久久| 久久中文精品视频| 91sao在线观看国产| 国产精品丝袜白浆摸在线| 久久久精品电影| 国产精品第一区| 日韩av成人在线观看| 国产欧美中文字幕| 91sao在线观看国产| 欧美大胆在线视频| 亚洲国产精品一区二区久| 欧美日韩国产999| 91久久精品国产91久久性色| 日韩欧美国产骚| 亚洲影视九九影院在线观看| 日韩精品中文字幕久久臀| 欧美亚洲免费电影| 亚洲少妇激情视频| 国产成人精品日本亚洲专区61| 久精品免费视频| 最近2019年中文视频免费在线观看| 97精品久久久| 国产成人97精品免费看片| 亚洲欧美成人一区二区在线电影| 一区二区三区视频免费在线观看| 97视频在线播放| 国产精品日韩欧美大师| 国产精品视频自在线| 国产91在线视频| 岛国精品视频在线播放| 欧美激情精品久久久| 欧美性xxxxxx| 精品久久久久久久久久久久久| 日韩在线中文视频| 国产97在线视频| 亚洲free性xxxx护士hd| 亚洲a一级视频| 国产精品视频大全| 欧美性高潮床叫视频| 欧美亚洲视频一区二区| 欧美激情精品久久久久久免费印度| 日韩高清有码在线| 亚洲一区中文字幕| xvideos亚洲| 欧美理论在线观看| 波霸ol色综合久久| 精品久久久久久久久久ntr影视| 国产日韩在线亚洲字幕中文| 日韩视频免费在线观看| 精品久久久久久久久久久| 国产视频久久久久久久| 毛片精品免费在线观看| 亚洲级视频在线观看免费1级| 麻豆精品精华液| 国产亚洲视频在线观看| 尤物yw午夜国产精品视频| 国产日韩精品在线播放| 欧美日韩在线第一页| 国产精品∨欧美精品v日韩精品| 中文字幕欧美亚洲| 国产精品久久久久久久久久久新郎| 亚洲九九九在线观看| 日本久久久久久| 美女扒开尿口让男人操亚洲视频网站| 亚洲视频一区二区| 性日韩欧美在线视频| yw.139尤物在线精品视频| 91欧美精品成人综合在线观看| 色综合久久悠悠| 欧美一级淫片丝袜脚交|