MongoDB怎樣進(jìn)行查詢耗時(shí)記錄
Admin 2022-11-17 群英技術(shù)資訊 1047 次瀏覽
今天小編跟大家講解下有關(guān)“MongoDB怎樣進(jìn)行查詢耗時(shí)記錄”的內(nèi)容 ,相信小伙伴們對(duì)這個(gè)話題應(yīng)該有所關(guān)注吧,小編也收集到了相關(guān)資料,希望小伙伴們看了有所幫助。準(zhǔn)備
在此之前,我們先在我們的數(shù)據(jù)庫(kù)中插入10萬條數(shù)據(jù)。數(shù)據(jù)的格式是這樣的:
{
"name":"your name",
"age":22,
"gender":"male",
"grade":2
}
explain
explain方法是用來查看db.collecion.find()的一些查詢信息的。例如:
db.collectionName.find().explain()
explain方法有個(gè)可選的參數(shù)verbose,是個(gè)字符串,他表示的是verbose的模式。一共分為3種模式:
queryPlanner:默認(rèn)參數(shù),詳細(xì)說明查詢優(yōu)化器選擇的計(jì)劃并列出被拒絕的計(jì)劃。例如:
db.students.find({grade:1}).explain()

executionStats:MongoDB運(yùn)行查詢優(yōu)化器選擇獲勝的計(jì)劃,執(zhí)行計(jì)劃,完成并返回成功,統(tǒng)計(jì)描述的勝利計(jì)劃的執(zhí)行。例如:
db.students.find({grade:1}).explain("executionStats")

allPlansExecution:MongoDB返回描述獲獎(jiǎng)計(jì)劃的執(zhí)行以及對(duì)其他候選人統(tǒng)計(jì)計(jì)劃選擇方案時(shí)捕獲的統(tǒng)計(jì)。
我們的目的是要記錄執(zhí)行find方法的耗時(shí)時(shí)間,所以用executionStats模式就可以了。
返回的結(jié)果也是只關(guān)注executionStats就可以了,如下圖:

其他的屬性在這里就不多說了,記錄耗時(shí)我們只取executionTimeMills.
Profiling
上面提到的方法好像是只適用find方法,對(duì)于一些聚合查詢之類的查詢方法就無法統(tǒng)計(jì)耗時(shí)時(shí)間了。這里再介紹一個(gè)profiling方法記錄查詢耗時(shí)時(shí)間。
開啟 Profiling 功能
有兩種方式可以控制 Profiling 的開關(guān)和級(jí)別,第一種是直接在啟動(dòng)參數(shù)里直接進(jìn)行設(shè)置。
db.setProfilingLevel(級(jí)別)命令來實(shí)時(shí)配置??梢酝ㄟ^db.getProfilingLevel()命令來獲取當(dāng)前的Profile級(jí)別。例如:
db.setProfilingLevel(2) db.getProfilingLevel()

Profiling一共分為3個(gè)級(jí)別:
Profile 記錄在級(jí)別1時(shí)會(huì)記錄慢命令,那么這個(gè)慢的定義是什么?上面我們說到其默認(rèn)為100ms,當(dāng)然有默認(rèn)就有設(shè)置,其設(shè)置方法和級(jí)別一樣有兩種,一種是通過添 加–slowms啟動(dòng)參數(shù)配置。第二種是調(diào)用db.setProfilingLevel時(shí)加上第二個(gè)參數(shù):
db.setProfilingLevel( level , slowms) db.setProfilingLevel( 1 , 10 );
查詢 Profiling 記錄
開啟profiling功能后,系統(tǒng)會(huì)把相關(guān)命令詳細(xì)信息記錄到當(dāng)前數(shù)據(jù)庫(kù)的system.profile集合里。查詢方法也是跟普通的集合查詢一樣。
db.system.profile.find()

其中,mills就是命令耗時(shí)記錄。
由于我們?cè)O(shè)置的級(jí)別是2,所以所有命令都有記錄,現(xiàn)在我們把他改為級(jí)別1,且只記錄耗時(shí)20毫秒以上的記錄:
db.setProfilingLevel( 1 , 20)

然后我們?cè)賵?zhí)行一下聚合查詢,查看下耗時(shí)時(shí)間:
db.students.aggregate( {$group:{_id:"$grade",avgAge:{$avg:"$age"}}} )

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

可以看出,我們的這聚合查詢耗時(shí)70毫秒。
profile 部分字段解釋
下面介紹幾個(gè)常用的查詢命令:
列出執(zhí)行時(shí)間長(zhǎng)于某一限度(例如:20ms)的 Profile 記錄.
db.system.profile.find({millis:{$gt:50}})

查看最新的 3條Profile 記錄:
db.system.profile.find().sort({$natural:-1}).limit(3)

查看關(guān)于某個(gè)collection的相關(guān)慢查詢操作:
db.system.profile.find({ns:'mydb.students'})
MongoDB 查詢優(yōu)化
docsExamined(掃描的記錄數(shù))遠(yuǎn)大于nreturned(返回結(jié)果的記錄數(shù))的話,那么我們就要考慮通過加索引來優(yōu)化記錄定位了。
responseLength 如果過大,那么說明我們返回的結(jié)果集太大了,這時(shí)請(qǐng)查看find函數(shù)的第二個(gè)參數(shù)是否只寫上了你需要的屬性名。(類似 于MySQL中不要總是select)
對(duì)于創(chuàng)建索引的建議是:如果很少讀,那么盡量不要添加索引,因?yàn)樗饕蕉?,寫操作?huì)越慢。如果讀量很大,那么創(chuàng)建索引還是比較劃算的。
Profiler 的效率
Profiling 功能肯定是會(huì)影響效率的,但是不太嚴(yán)重,原因是他使用的是system.profile 來記錄,而system.profile 是一個(gè)capped collection 這種collection 在操作上有一些限制和特點(diǎn),但是效率更高。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:[email protected]進(jìn)行舉報(bào),并提供相關(guān)證據(jù),查實(shí)之后,將立刻刪除涉嫌侵權(quán)內(nèi)容。
猜你喜歡
這篇文章主要給大家分享mongodb添加arbiter節(jié)點(diǎn)的步驟和過程,對(duì)大家了解mongodb添加節(jié)點(diǎn)有一定的幫助,感興趣的朋友可以參考一下,希望大家閱讀完這篇文章能有所收獲,下面我們一起來學(xué)習(xí)一下吧。
MongoDB默認(rèn)使用_id字段作為主鍵,類型為ObjectId。ObjectId的生成有一定的規(guī)則,詳情可以查看這篇文章MongoDB深究之ObjectId
在學(xué)習(xí)MongoDB中我們需要學(xué)習(xí)的知識(shí)有非常多,對(duì)于新手用戶來說是很難記住的,那么下面我們就一起去看看MongoDB常用操作和基礎(chǔ)知識(shí)有哪些吧!
MongoDB 分片 分片 在Mongodb里面存在另一種集群,就是分片技術(shù),可以滿足MongoDB數(shù)據(jù)量大量增長(zhǎng)的需求。 當(dāng)MongoDB存儲(chǔ)海量的數(shù)據(jù)時(shí),一臺(tái)機(jī)器可能不足以存儲(chǔ)數(shù)據(jù),也可能不足以提供可接受的讀寫吞吐量。這時(shí),我們就可以通過在多臺(tái)機(jī)器上分割數(shù)據(jù),使得數(shù)據(jù)庫(kù)系統(tǒng)能存儲(chǔ)和處理更多的數(shù)據(jù)。 為什么使用分片 復(fù)制所有的寫入操作到主節(jié)點(diǎn) 延遲的敏感數(shù)據(jù)會(huì)在主節(jié)點(diǎn)查詢 單個(gè)副本集限制在12個(gè)節(jié)點(diǎn) 當(dāng)請(qǐng)求量巨大時(shí)會(huì)出現(xiàn)內(nèi)存不..
這篇文章給大家分享的是MongoDB中的增刪改查方法的相關(guān)內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,文中示例有一定的參考價(jià)值,感興趣的朋友接下來一起跟隨小編看看吧。
推薦內(nèi)容
相關(guān)標(biāo)簽
成為群英會(huì)員,開啟智能安全云計(jì)算之旅
立即注冊(cè)關(guān)注或聯(lián)系群英網(wǎng)絡(luò)
7x24小時(shí)售前:400-678-4567
7x24小時(shí)售后:0668-2555666
24小時(shí)QQ客服
群英微信公眾號(hào)
CNNIC域名投訴舉報(bào)處理平臺(tái)
服務(wù)電話:010-58813000
服務(wù)郵箱:[email protected]
投訴與建議:0668-2555555
Copyright ? QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版權(quán)所有
增值電信經(jīng)營(yíng)許可證 : B1.B2-20140078 ICP核準(zhǔn)(ICP備案)粵ICP備09006778號(hào) 域名注冊(cè)商資質(zhì) 粵 D3.1-20240008