好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MongoDB如何查詢耗時記錄的方法詳解

MongoDB如何查詢耗時記錄的方法詳解

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

準(zhǔn)備

在此之前,我們先在我們的數(shù)據(jù)庫中插入10萬條數(shù)據(jù)。數(shù)據(jù)的格式是這樣的:

{
 "name":"your name",
 "age":22,
 "gender":"male",
 "grade":2
}

explain

explain方法是用來查看db.collecion.find()的一些查詢信息的。例如:

db.collectionName.find().explain()

explain方法有個可選的參數(shù)verbose,是個字符串,他表示的是verbose的模式。一共分為3種模式:

queryPlanner:默認(rèn)參數(shù),詳細(xì)說明查詢優(yōu)化器選擇的計劃并列出被拒絕的計劃。例如:

db.students.find({grade:1}).explain()

executionStats:MongoDB運行查詢優(yōu)化器選擇獲勝的計劃,執(zhí)行計劃,完成并返回成功,統(tǒng)計描述的勝利計劃的執(zhí)行。例如:

db.students.find({grade:1}).explain("executionStats")


allPlansExecution:MongoDB返回描述獲獎計劃的執(zhí)行以及對其他候選人統(tǒng)計計劃選擇方案時捕獲的統(tǒng)計。
我們的目的是要記錄執(zhí)行find方法的耗時時間,所以用executionStats模式就可以了。

返回的結(jié)果也是只關(guān)注executionStats就可以了,如下圖:


  1. nReturned:表示該查詢條件下返回的文檔數(shù)量。
  2. executionTimeMills:表示執(zhí)行時間,單位毫秒
  3. totalDocsExamined:表示該集合總共文檔數(shù)。

其他的屬性在這里就不多說了,記錄耗時我們只取executionTimeMills.

Profiling

上面提到的方法好像是只適用find方法,對于一些聚合查詢之類的查詢方法就無法統(tǒng)計耗時時間了。這里再介紹一個profiling方法記錄查詢耗時時間。

開啟 Profiling 功能

有兩種方式可以控制 Profiling 的開關(guān)和級別,第一種是直接在啟動參數(shù)里直接進(jìn)行設(shè)置。

  • 啟動MongoDB時加上–profile=級別 即可。
  • 也可以在客戶端調(diào)用db.setProfilingLevel(級別)命令來實時配置。可以通過db.getProfilingLevel()命令來獲取當(dāng)前的Profile級別。

例如:

db.setProfilingLevel(2)
db.getProfilingLevel()

Profiling一共分為3個級別:

  • 0 - 不開啟。
  • 1 - 記錄慢命令 (默認(rèn)為>100ms)
  • 3 - 記錄所有命令

Profile 記錄在級別1時會記錄慢命令,那么這個慢的定義是什么?上面我們說到其默認(rèn)為100ms,當(dāng)然有默認(rèn)就有設(shè)置,其設(shè)置方法和級別一樣有兩種,一種是通過添 加–slowms啟動參數(shù)配置。第二種是調(diào)用db.setProfilingLevel時加上第二個參數(shù):

db.setProfilingLevel( level , slowms)
db.setProfilingLevel( 1 , 10 );

查詢 Profiling 記錄

開啟profiling功能后,系統(tǒng)會把相關(guān)命令詳細(xì)信息記錄到當(dāng)前數(shù)據(jù)庫的system.profile集合里。查詢方法也是跟普通的集合查詢一樣。

db.system.profile.find()

其中,mills就是命令耗時記錄。

由于我們設(shè)置的級別是2,所以所有命令都有記錄,現(xiàn)在我們把他改為級別1,且只記錄耗時20毫秒以上的記錄:

 db.setProfilingLevel( 1 , 20)

然后我們再執(zhí)行一下聚合查詢,查看下耗時時間:

db.students.aggregate( {$group:{_id:"$grade",avgAge:{$avg:"$age"}}} )

db.system.profile.find().pretty()


可以看出,我們的這聚合查詢耗時70毫秒。

profile 部分字段解釋

  • op:操作類型
  • ns:被查的集合
  • commond:命令的內(nèi)容
  • docsExamined:掃描文檔數(shù)
  • nreturned:返回記錄數(shù)
  • millis:耗時時間,單位毫秒
  • ts:命令執(zhí)行時間
  • responseLength:返回內(nèi)容長度

下面介紹幾個常用的查詢命令:

列出執(zhí)行時間長于某一限度(例如:20ms)的 Profile 記錄.

db.system.profile.find({millis:{$gt:50}})

查看最新的 3條Profile 記錄:

db.system.profile.find().sort({$natural:-1}).limit(3)

查看關(guān)于某個collection的相關(guān)慢查詢操作:

db.system.profile.find({ns:'mydb.students'})

MongoDB 查詢優(yōu)化

  docsExamined(掃描的記錄數(shù))遠(yuǎn)大于nreturned(返回結(jié)果的記錄數(shù))的話,那么我們就要考慮通過加索引來優(yōu)化記錄定位了。

  responseLength 如果過大,那么說明我們返回的結(jié)果集太大了,這時請查看find函數(shù)的第二個參數(shù)是否只寫上了你需要的屬性名。(類似 于MySQL中不要總是select)

  對于創(chuàng)建索引的建議是:如果很少讀,那么盡量不要添加索引,因為索引越多,寫操作會越慢。如果讀量很大,那么創(chuàng)建索引還是比較劃算的。

Profiler 的效率

  Profiling 功能肯定是會影響效率的,但是不太嚴(yán)重,原因是他使用的是system.profile 來記錄,而system.profile 是一個capped collection 這種collection 在操作上有一些限制和特點,但是效率更高。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 關(guān)于Mongodb 認(rèn)證鑒權(quán)你需要知道的一些事
  • linux系統(tǒng)下MongoDB單節(jié)點安裝教程
  • vue+socket.io+express+mongodb 實現(xiàn)簡易多房間在線群聊示例
  • node.js操作MongoDB的實例詳解
  • windows7下使用MongoDB實現(xiàn)倉儲設(shè)計
  • java操作mongoDB查詢的實例詳解
  • MongoDB 3.4 安裝以 Windows 服務(wù)方式運行的詳細(xì)步驟
  • 詳解MongoDB數(shù)據(jù)庫基礎(chǔ)操作及實例
  • MongoDB TTL索引的實例詳解

標(biāo)簽:玉林 自貢 遼陽 廈門 泰安 興安盟 雞西 無錫

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MongoDB如何查詢耗時記錄的方法詳解》,本文關(guān)鍵詞  MongoDB,如何,查詢,耗時,記錄,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MongoDB如何查詢耗時記錄的方法詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于MongoDB如何查詢耗時記錄的方法詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产熟妇婬乱A片免费看图片直播| 国产精品一级香蕉一区| 拨开女人湿漉漉的两片看看| 边摸边吃奶边做很爽视频免费| 欲梦自慰??喷水无优传媒| 亚洲秘?无码一区二区三区欧美| 又黄又爽做受视频免费看视频下载 | 污网站进入| 国产精产国品一二三产区区别| 国产欧美熟妇另类久久久 | 国产高清ww又色又爽又猛| 秋霞电影院网伦霞免费| 爽好舒服快深点小说| 24小时日本免费观看完整版| 亚洲AV天堂资源网mmd| 亲胸揉胸膜下刺激视频风险评估| 亚洲无矿砖砖区| 亚洲依依成人精品| 黄色大片在线免费观看| 91人妻精品国产一区| 91无码粉嫩小泬无套在线哈尔滨| 国产高清在线观看视频手机版| 91免费国产| 韩剧华丽的外出| 96久久久久久精品9999A片| 被夫上司连续被7天侵犯bd| 白莲花被强h宝贝水真多小说| 潘金莲西门庆吃奶一级| 伊大人香蕉久久网欧美| 麻豆chinese野外videosbbw| 亚洲精品一区国产精品| 美女啪啪动态| 日本人妻无码ⅩXXXXX| 中国一级特黄毛片大片| 国产成年免费网站1688| 污软件下载| 国产黄A三级三级三级看三级男男| 久久久精品无码| a级片免费电影| 欧美午夜视频一区二区三区| 精品无码一区二区三区四区久久久 |