麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > MongoDB > 正文

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

2024-09-07 00:22:34
字體:
來源:轉載
供稿:網友
       文本主要給大家介紹的是關于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()
 
 
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)
 
       Profiler 的效率
 
  Profiling 功能肯定是會影響效率的,但是不太嚴重,原因是他使用的是system.profile 來記錄,而system.profile 是一個capped collection 這種collection 在操作上有一些限制和特點,但是效率更高。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美国产一区二区三区 | 免费久久久久 | 精品国产一区二区三区在线 | 天天看成人免费毛片视频 | 一区二区精品视频在线观看 | 伊人久久电影网 | 一级电影在线观看 | 一级毛片免费高清视频 | 一级黄色影院 | 亚洲免费资源 | 亚洲特黄a级毛片在线播放 久久久入口 | 久久噜噜噜精品国产亚洲综合 | 色播视频在线播放 | 国产精品久久久久久久久岛 | 亚洲精久 | 一级黄色欧美 | 欧美黄 片免费观看 | 精品人伦一区二区三区蜜桃网站 | 国产超碰人人做人人爱ⅴa 国产精品久久久久久久hd | 黄色片网站免费在线观看 | 欧美重口另类videos人妖 | 久久久久久久久久久亚洲 | 国产九九| 视频一区二区精品 | 国产成人免费精品 | 欧美zoofilia杂交videos | 成人免费在线播放 | 免费a视频 | 老女人碰碰在线碰碰视频 | 看免费的毛片 | 精品国产乱码久久久久久丨区2区 | 久久亚洲网 | 在线看小早川怜子av | 康妮卡特欧美精品一区 | 欧美精品一二三区 | 久久亚洲综合色 | 国产精品区在线12p 午夜视频色 | h视频免费看 | 亚洲电影免费观看国语版 | 中文字幕精品在线播放 | 久久免费视频7 |