欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB數(shù)據(jù)庫查看慢查詢級別以及慢查詢?nèi)罩?/h1>
 更新時間:2023年05月24日 10:55:23   作者:阿福Chris  
最近項(xiàng)目上一直在用mongodb作為數(shù)據(jù)庫,mongodb有他的優(yōu)勢,文檔型類json格式存儲數(shù)據(jù),修改起來更方便,但是最近在用mongodb出現(xiàn)了查詢緩慢的問題,這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫查看慢查詢級別以及慢查詢?nèi)罩镜南嚓P(guān)資料,需要的朋友可以參考下

1. MongoDB 慢查詢記錄功能簡介

如何定位 MongoDB 數(shù)據(jù)庫的慢查詢,我想應(yīng)該是很多剛使用 MongoDB 數(shù)據(jù)庫的朋友最想知道的問題。通過慢查詢的定位,可以輔助對 MongoDB 中的 collection 進(jìn)行優(yōu)化。

MongoDB 數(shù)據(jù)庫的慢查詢數(shù)據(jù)其實(shí)存放在一個數(shù)據(jù)庫集合 ( collection ) 中(system.profile),如果你不主動創(chuàng)建 system.profile 這個集合,那這個集合就固定1M大小,當(dāng)慢查詢記錄超過1M,就會將歷史數(shù)據(jù)覆蓋,循環(huán)使用,所以在這里需要根據(jù)業(yè)務(wù)實(shí)際情況設(shè)置集合大小。

在 MongoDB 中慢查詢功能(Profiling)設(shè)置有三個級別,分別代表如下含義:

  • 0:代表關(guān)閉,不收集任何慢查詢
  • 1:收集慢查詢數(shù)據(jù),默認(rèn)收集超過100毫秒的慢查詢
  • 2:收集任何操作記錄數(shù)據(jù)

可以通過在 MongoDB 中執(zhí)行如下命令查看當(dāng)前數(shù)據(jù)庫的配置,需要特別注意的是,如果你在某一數(shù)據(jù)庫中調(diào)整了該設(shè)置,那么該操作只對該數(shù)據(jù)庫有效,其他數(shù)據(jù)庫仍需要單獨(dú)設(shè)置:

use test
'switched to db test'
db.getProfilingStatus()
{ was: 1, slowms: 1000, sampleRate: 1, ok: 1 }

2. 如何設(shè)置慢查詢

2.1 檢查慢查詢是否開啟

執(zhí)行 db.getProfilingStatus() 查詢數(shù)據(jù)庫,返回結(jié)果是 was: 0 代表 MongoDB 沒有開啟慢查詢功能;對應(yīng)的如果不是 0 則表示開啟了慢查詢監(jiān)控功能。

2.2 開啟慢查詢功能

如果你想指定監(jiān)控慢查詢在某一毫秒值之上的查詢,例如超過 1000 毫秒的查詢被記錄,可以通過如下語句進(jìn)行設(shè)置:

db.setProfilingLevel(1, {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> slowms: 1000 })

下面這個例子表示將慢查詢的級別設(shè)置為 2

db.setProfilingLevel(2)
{ was: 1, slowms: 500, sampleRate: 1, ok: 1 }
db.getProfilingStatus()
{ was: 2, slowms: 500, sampleRate: 1, ok: 1 }

關(guān)掉慢查詢功能

db.setProfilingLevel(0)

3. 如何查詢慢查詢?nèi)罩?/h2>

假設(shè)上面我們已經(jīng)開啟了慢查詢監(jiān)控功能,那在數(shù)據(jù)庫使用過程中,會將 1000 ms 以上的執(zhí)行查詢進(jìn)行記錄,下面我們來看一下如何查詢這些慢查詢。

3.1 慢查詢?nèi)罩静榭?/h3>

查詢最近的 10 個慢查詢?nèi)罩?(運(yùn)行時間大于等于 8000 毫秒)

db.system.profile.find({"millis":{$gte:8000}}).limit(10).sort( { ts : -1 } ).pretty()

查詢大于 100 秒的日志

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

查詢時間從 2023-01-03 15 點(diǎn)整到 2023-01-03 15點(diǎn)30分 之間的日志

db.system.profile.find({ts : {$gt: new ISODate("2023-01-03T07:00:00Z"),$lt: new ISODate("2023-01-03T07:30:00Z")}}).pretty()

備注:注意 Mongo 里面存儲的 ISO 時間是格林尼治時間,我們當(dāng)前CST時間為北京時間,需要在 ISO 上 +8,所以你可以看到上面我查詢輸入的時間為 7 點(diǎn),但實(shí)際上查詢的是 15 點(diǎn)的數(shù)據(jù)。

補(bǔ)充:mongodb慢查詢了怎么辦

如果你的 MongoDB 數(shù)據(jù)庫中出現(xiàn)了慢查詢,你可以嘗試以下幾種方法來解決問題:

找出導(dǎo)致慢查詢的原因:

使用 MongoDB 的 explain() 方法來分析查詢的執(zhí)行計(jì)劃,找出導(dǎo)致慢查詢的原因。

啟用 MongoDB 的慢查詢?nèi)罩竟δ?,記錄慢查詢的詳?xì)信息,并分析日志中出現(xiàn)的問題。

優(yōu)化查詢:

盡量使用索引來優(yōu)化查詢,避免使用全表掃描。

盡量減少查詢中的返回字段數(shù)量,只返回必要的字段。

使用合適的查詢方式,例如使用 $in 代替 OR 運(yùn)算符。

優(yōu)化數(shù)據(jù)庫結(jié)構(gòu):

對于頻繁查詢的字段,盡量使用索引。

合理劃分分片,避免數(shù)據(jù)傾斜。

合理設(shè)置集合的副本數(shù)量,保證數(shù)據(jù)的可用性。

擴(kuò)展硬件資源:

如果數(shù)據(jù)庫的硬件資源限制了查詢性能,可以考慮增加 CPU、內(nèi)存或磁盤空間等資源。

總結(jié)

到此這篇關(guān)于MongoDB數(shù)據(jù)庫查看慢查詢級別以及慢查詢?nèi)罩镜奈恼戮徒榻B到這了,更多相關(guān)MongoDB查看慢查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決mongo的tickets被耗盡導(dǎo)致卡頓問題

    解決mongo的tickets被耗盡導(dǎo)致卡頓問題

    這篇文章主要介紹了解決mongo的tickets被耗盡導(dǎo)致卡頓問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • MongoDB分片詳解

    MongoDB分片詳解

    本文分享了MongoDB分片詳細(xì)介紹,分片是MongoDB的擴(kuò)展方式,通過分片能夠增加更多的機(jī)器來用對不斷增加的負(fù)載和數(shù)據(jù),還不影響應(yīng)用,
    2018-03-03
  • MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例介紹

    MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例介紹

    雖然MongoDB這些年很流行,但筆者之前沒研究過,現(xiàn)在有需求研究這類NoSQL的數(shù)據(jù)庫,是為了驗(yàn)證其是否可被替換,本文給大家介紹MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例詳解,感興趣的朋友一起看看吧
    2024-07-07
  • MongoDB.NET 2.2.4驅(qū)動版本對Mongodb3.3數(shù)據(jù)庫中GridFS增刪改查

    MongoDB.NET 2.2.4驅(qū)動版本對Mongodb3.3數(shù)據(jù)庫中GridFS增刪改查

    這篇文章主要為大家詳細(xì)介紹了使用MongoDB.NET 2.2.4驅(qū)動版本對Mongodb3.3數(shù)據(jù)庫中GridFS增刪改查,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 詳解mongodb搭建Replica Set的方法

    詳解mongodb搭建Replica Set的方法

    這篇文章主要介紹了mongodb搭建Replica Set的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • 記一次Mongodb中admin數(shù)據(jù)庫導(dǎo)致的事故

    記一次Mongodb中admin數(shù)據(jù)庫導(dǎo)致的事故

    這篇文章主要給大家介紹了關(guān)于一次Mongodb中admin數(shù)據(jù)庫導(dǎo)致的事故的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • MongoDB數(shù)據(jù)庫常用的10條操作命令

    MongoDB數(shù)據(jù)庫常用的10條操作命令

    MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由 C++ 語言編寫。旨在為 WEB 應(yīng)用提供可擴(kuò)展的高性能數(shù)據(jù)存儲解決方案。本文簡單的介紹一些MongoDB數(shù)據(jù)庫常用的操作命令
    2021-06-06
  • MongoDB中文檔的更新操作示例詳解

    MongoDB中文檔的更新操作示例詳解

    這篇文章主要給大家介紹了關(guān)于MongoDB中文檔的更新操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • mongodb中隨機(jī)獲取1條記錄的實(shí)現(xiàn)方法

    mongodb中隨機(jī)獲取1條記錄的實(shí)現(xiàn)方法

    這篇文章運(yùn)用實(shí)例給大家演示了如何在mongodb中隨機(jī)獲取1條記錄,文中介紹的很詳細(xì),有需要的朋友們可以參考借鑒。下面來一起看看吧。
    2016-09-09
  • MongoDB實(shí)現(xiàn)備份壓縮的方法教程

    MongoDB實(shí)現(xiàn)備份壓縮的方法教程

    這篇文章主要給大家介紹了關(guān)于MongoDB實(shí)現(xiàn)備份壓縮的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09

最新評論