成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > MongoDB使用profile分析慢查詢的步驟

MongoDB使用profile分析慢查詢的步驟

熱門標(biāo)簽:長(zhǎng)沙電銷外呼防封卡是什么 內(nèi)蒙古營(yíng)銷智能外呼系統(tǒng)哪個(gè)好 crm外呼系統(tǒng)聯(lián)系方式 外呼線路資源屬于電信業(yè)務(wù)嗎 呼和浩特外呼系統(tǒng)原理是什么 青白江400企業(yè)電話申請(qǐng) 智能外呼系統(tǒng)官網(wǎng) 小裙科技電銷機(jī)器人怎樣 河南電話外呼系統(tǒng)招商

      在MongoDB中,如果發(fā)生了慢查詢,我們?nèi)绾蔚玫竭@些慢查詢的語(yǔ)句,并優(yōu)化呢?今天來(lái)看這塊兒的一些心得。

01 如何收集慢查詢?

    在MongoDB中,通常可以開啟profile來(lái)收集慢日志,查看當(dāng)前profile狀態(tài)的語(yǔ)句如下:

test1:PRIMARY> db.getProfilingStatus()
{
        "was" : 2,
        "slowms" : 0,
        "sampleRate" : 1,
        "$gleStats" : {
                "lastOpTime" : Timestamp(0, 0),
                "electionId" : ObjectId("7fffffff0000000000000005")
        },
        "lastCommittedOpTime" : Timestamp(1619186976, 2),
        "$configServerState" : {
                "opTime" : {
                        "ts" : Timestamp(1619186976, 1),
                        "t" : NumberLong(2)
                }
        },
        "$clusterTime" : {
                "clusterTime" : Timestamp(1619186976, 2),
                "signature" : {
                        "hash" : BinData(0,"zvwFpgc0KFxieMpj7mBPdrOnonI="),
                        "keyId" : NumberLong("6904838687771590657")
                }
        },
        "operationTime" : Timestamp(1619186976, 2)
}

這里我們可以看到2個(gè)關(guān)鍵參數(shù),分別是was和slowms,其中:

was=0,代表不記錄任何的語(yǔ)句;

was=1,代表記錄執(zhí)行時(shí)間超過slowms的語(yǔ)句

was=2,代表記錄所有的語(yǔ)句

slowms代表語(yǔ)句的閾值,單位是ms

上圖中的結(jié)果代表我們的實(shí)例會(huì)收集所有的查詢語(yǔ)句。profile收集的查詢語(yǔ)句結(jié)果存放在admin數(shù)據(jù)庫(kù)中的system.profile集合中,可以通過下面的方法進(jìn)行訪問:

test1:PRIMARY> use admin
switched to db admin

test1:PRIMARY> db.system.profile.find({'op':'query'},{'op':1,'ns':1,'millis':1,'ts':1})
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:14.815Z") }
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:15.139Z") }
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:15.141Z") }
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:15.239Z") }
{ "op" : "query", "ns" : "admin.system.version", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:16.155Z") }
{ "op" : "query", "ns" : "admin.system.version", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:16.192Z") }
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:16.225Z") }
{ "op" : "query", "ns" : "admin.system.users", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:16.273Z") }
{ "op" : "query", "ns" : "admin.system.version", "millis" : 0, "ts" : ISODate("2020-08-27T07:22:16.276Z") }

02 system.profile慢查詢集合分析

   admin數(shù)據(jù)庫(kù)中的system.profile是一個(gè)固定集合,保存著超過設(shè)置的慢查詢的結(jié)果。我們來(lái)看里面的一條慢查詢。

    利用下面的方法,來(lái)拿到一條數(shù)據(jù),并對(duì)其中的關(guān)鍵字段進(jìn)行注釋說(shuō)明:

test1:PRIMARY> db.system.profile.findOne({'op':'query'})
{
        "op" : "query",  # 操作類型
        "ns" : "admin.system.users",  # 命名空間
        "command" : {
                "find" : "system.users",
                "filter" : {
                        "_id" : "admin.root"  # 過濾的字段
                },
                "limit" : 1,
                "singleBatch" : true,
                "lsid" : {
                        "id" : UUID("a6034f5e-77c1-4b19-9669-60e1253edf4b")
                },
                "$readPreference" : {
                        "mode" : "secondaryPreferred"
                },
                "$db" : "admin"
        },
        "keysExamined" : 1,   # 掃描的索引數(shù)
        "docsExamined" : 1,   # 掃描的行數(shù)
        "cursorExhausted" : true,  
        "numYield" : 0,
        "nreturned" : 1,   # 返回的值的行數(shù)
        "locks" : {
                xxxx   #  鎖信息
        },
        "flowControl" : {

        },
        "storage" : {
        },
        "responseLength" : 647,
        "protocol" : "op_query",
        "millis" : 0,    # 這個(gè)查詢的執(zhí)行時(shí)間,因?yàn)槲覀冊(cè)O(shè)置的profilestatus是0,因此所有操作都被記錄了。
        "planSummary" : "IDHACK",  # 針對(duì)_id進(jìn)行查詢
        "execStats" : {   # 查詢執(zhí)行狀態(tài)
                "stage" : "IDHACK",
                "nReturned" : 1,
                "executionTimeMillisEstimate" : 0,
                "works" : 2,
                "advanced" : 1,
                "needTime" : 0,
                "needYield" : 0,
                "saveState" : 0,
                "restoreState" : 0,
                "isEOF" : 1,
                "keysExamined" : 1,
                "docsExamined" : 1
        },
        "ts" : ISODate("2020-08-27T07:22:14.815Z"),
        "client" : "xx.xx.xx.xx",  # 查詢的客戶端IP地址
        "allUsers" : [   #  所有的用戶信息
                {
                        "user" : "root",
                        "db" : "admin"
                }
        ],
        "user" : "root@admin"   # 使用的用戶信息
}

03 慢查詢分析利器---explain

   通常情況下,我們可以使用MongoDB的explain語(yǔ)法來(lái)分析一個(gè)語(yǔ)句的查詢性能,包含是否用到索引、掃描行數(shù)等信息,explain語(yǔ)法的基本用法:

后置寫法
db.system.profile.find({'op':'query'}).explain()
前置寫法
db.system.profile.explain().find({'op':'query'})

其中,explain可以放在查詢語(yǔ)句的后面或者前面,當(dāng)然find語(yǔ)法也可以是update、remove、insert

explain語(yǔ)法的輸出分為3種不同的詳細(xì)程度,分別如下:

三種清晰度模式,清晰度越高,則輸出的信息越全,默認(rèn)情況下是queryPlanner:

1、queryPlanner模式(默認(rèn))
db.products.explain().count( { quantity: { $gt: 50 } } )

2、executionStats模式
db.products.explain("executionStats").count( { quantity: { $gt: 50 } } )

3、allPlansExecution模式
db.products.explain("allPlansExecution").count( { quantity: { $gt: 50 } } )

其中,allPlansExecution模式輸出的信息最多。

下面是一個(gè)explain語(yǔ)法的輸出內(nèi)容,查詢的SQL如下:

db.getCollection('files').find(
{"cTime":{
           "$gte":ISODate("2021-04-18"),
           "$lt":ISODate("2021-04-19")
       }}).limit(1000).explain("allPlansExecution")

輸出的結(jié)果如下:

{
        "queryPlanner" : {   # 代表查詢的執(zhí)行計(jì)劃
                "plannerVersion" : 1,   # 版本號(hào)
                "namespace" : "fs.files",   # 查詢的命名空間,也就是集合名稱
                "indexFilterSet" : false,   # 是否使用了索引過濾,注意,它并不能判定是否使用了索引
                "parsedQuery" : {    # 查詢語(yǔ)法解析樹
                        "$and" : [
                                {
                                        "cTime" : {
                                                "$lt" : ISODate("2021-04-19T00:00:00Z")
                                        }
                                },
                                {
                                        "cTime" : {
                                                "$gte" : ISODate("2021-04-18T00:00:00Z")
                                        }
                                }
                        ]
                },
                "winningPlan" : {    # 最終選擇的查詢計(jì)劃
                        "stage" : "LIMIT",   # 查詢的階段,很重要,下面詳細(xì)介紹
                        "limitAmount" : 1000,   # 查詢結(jié)果的limit值
                        "inputStage" : {
                                "stage" : "FETCH",
                                "inputStage" : {
                                        "stage" : "IXSCAN",  # 代表索引掃描
                                        "keyPattern" : {
                                                "cTime" : 1
                                        },
                                        "indexName" : "cTime_1",  #  索引名稱
                                        "isMultiKey" : false,    # 下面4個(gè)字段都是索引類型分析
                                        "isUnique" : false,
                                        "isSparse" : false,
                                        "isPartial" : false,
                                        "indexVersion" : 1,
                                        "direction" : "forward",
                                        "indexBounds" : {
                                                "cTime" : [
                                                        "[new Date(1618704000000), new Date(1618790400000))"
                                                ]
                                        }
                                }
                        }
                },
                "rejectedPlans" : [ ]  # 候選的沒被選中的查詢計(jì)劃
        },
        "serverInfo" : {
                "host" : "xxxx",
                "port" : 24999,
                "version" : "3.2.8",
                "gitVersion" : "ed70e33130c977bda0024c125b56d159573dbaf0"
        },
        "ok" : 1
}

首先解釋下stage的幾個(gè)階段:

  1. COLLSCAN---全表掃描
  2. IXSCAN---索引掃描
  3. FETCH---根據(jù)索引去檢索文檔
  4. SHARD_MERGE---合并分片結(jié)果
  5. IDHACK---針對(duì)id進(jìn)行查詢
  6. LIMIT---執(zhí)行l(wèi)imit

了解了這些stage的階段之后,我們可以看到,一個(gè)查詢的過程是一層一層解析的,所以可以看到,stage這個(gè)字段有嵌套的情況。winningPlan中的執(zhí)行計(jì)劃也是按照一層一層的順序去執(zhí)行:

1、先執(zhí)行最內(nèi)層的索引掃描(IXSCAN);

2、再執(zhí)行外面的FETCH,根據(jù)索引去拿文檔

3、執(zhí)行最后一步的limit,取指定數(shù)目個(gè)結(jié)果返回給客戶端

以上就是MongoDB profile分析慢查詢的示例的詳細(xì)內(nèi)容,更多關(guān)于MongoDB profile分析慢查詢的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • 深入講解MongoDB的慢日志查詢(profile)

標(biāo)簽:池州 菏澤 舟山 呼倫貝爾 黃石 白山 安順 楚雄

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MongoDB使用profile分析慢查詢的步驟》,本文關(guān)鍵詞  MongoDB,使用,profile,分析,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MongoDB使用profile分析慢查詢的步驟》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MongoDB使用profile分析慢查詢的步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美久久在线| 欧美精品人人做人人爱视频| 视频在线观看入口黄最新永久免费国产| 视频在线观看一区| 久久都是精品| 婷婷成人综合网| 精品无码久久久久国产| 日韩av一卡二卡三卡| 亚洲第一视频在线| 国产精品国产三级国产aⅴ浪潮| 麻豆福利在线观看| 中文字幕被公侵犯的漂亮人妻| 国产成人精品亚洲| 你懂得在线网址| 国产欧美日本亚洲精品一4区| 蜜臀av一区二区在线免费观看| 成人午夜免费视频| 色呦呦一区二区| 岛国一区二区三区高清视频| 美女一区二区在线观看| 久久精品国产亚洲一区二区三区| 朝桐光一区二区| 国产中文字幕免费| 欧美国产日韩一区二区在线观看| 国产精品自产拍在线观看2019| 欧美日韩一二三四区| 夜夜亚洲天天久久| 波多野结衣毛片| 国产精选久久久| 亚洲国产精品久久久久| 久久久影院免费| 91成人精品一区二区| 精品一区二区三| 日本久久一级片| 日韩伦理一区二区| 成人精品久久一区二区三区| 亚洲欧美日韩视频一区| 国产福利第一视频| 国产又粗又猛又爽又黄的视频小说| 不卡的电视剧免费网站有什么| 91精品国产乱码久久久竹菊| 麻豆精品一区| 内射国产内射夫妻免费频道| 欧美一级视频免费观看| 国产成人丝袜美腿| 久久久久久久国产精品影院| 久久99性xxx老妇胖精品| 亚洲天堂av片| www日本在线| 精品全国在线一区二区| 在线观看av网站| 国产精品av久久久久久麻豆网| 日本高清黄色片| 精品国产三级| 国产精品久久久久免费| 7878视频在线观看| 麻豆视频在线免费看| 国产三级av片| 亚洲大肥女ass| 国产免费色视频| 欧美a v在线播放| 亚洲黄色尤物视频| 345成人影院| 日本私人网站在线观看| 9191久久久久久久久久久| 国产欧美一区二区精品久导航| 国产在线88av| 天天看片天天操| 91久久午夜| 一级黄色大毛片| 性xx十八spa按摩| 菠萝蜜一区二区| 香蕉久久久久久| 成熟丰满熟妇高潮xxxxx视频| 国产精品黄色在线观看| 精品福利一区二区| 免费无遮挡无码永久视频| 国产精品久久久久久久久久久久久久久| 亚洲热av色在线播放| 国产成人精品免费久久久久| 精品久久久无码人妻字幂| 中文字幕永久在线不卡| 黄色影片网站| 国产黄a三级三级| 天天好比中文综合网| 日韩中文字幕网| 黄色大片a级| 欧美一级大片在线视频| 最新av网站在线观看| www.久久久久.com| 亚洲人成网站影音先锋播放| 日本一二三四区视频| 日韩激情欧美| 污网站免费看| 色999韩欧美国产综合俺来也| 国产精品无码一区| 一本色道精品久久一区二区三区| www日韩精品| 免费人成自慰网站| 在线日韩欧美| 精品爆乳一区二区三区无码av| 欧美高清视频一二三区| 亚洲自拍中文字幕| 欧美日韩视频免费播放| 精品乱子伦一区二区| 午夜电影一区二区| 羞羞小视频视频| 成人天堂噜噜噜| 欧美日韩 国产精品| 久久亚洲视频| 国产精品日日摸夜夜摸av| 黄色成人在线网站| 亚洲成人影院在线观看| 天天干天天摸天天操| 婷婷久久综合九色国产成人| 精品噜噜噜噜久久久久久久久试看| 亚洲精品不卡在线| 狠狠v欧美v日韩v亚洲ⅴ| 久久www免费人成精品| 午夜精品久久99蜜桃的功能介绍| 在线成人精品视频| 99在线高清视频在线播放| 日韩黄色短视频| 麻豆mv在线看| 91肉色超薄丝袜脚交一区二区| 成人高清免费观看mv| 国产一区二三区| 中文字幕人妻色偷偷久久| 青青青国产在线视频| 中文字幕免费一区二区| 韩国女主播一区二区三区| 亚洲精品国产嫩草在线观看| 蜜桃av色综合| 日本精品在线一区| 精品国产乱码久久久久久蜜臀网站| xvideos成人免费中文版| 日韩av高清在线播放| 在线免费一区二区| 成人永久在线| 精品中文字幕在线播放| 黄色毛片在线| 久久久噜噜噜久久中文字幕色伊伊| 中文在线资源新版官网| 在线中文字幕一区二区| 麻豆成全视频免费观看在线看| 五月婷婷在线观看视频| 国产亚洲精品久久| 一本色道久久综合亚洲精品不| 国产精品jizz在线观看老狼| 91黑人精品一区二区三区| 日韩欧美精品在线观看视频| xxxx欧美18另类的高清| 日本不卡中文字幕| 日韩av一区在线观看| 亚洲一二三区在线观看| 欧美最猛性xxxxxhd| 亚洲无线一线二线三线区别av| 亚洲色偷偷色噜噜狠狠99网| 欧美电影完整版在线观看| 夜夜夜夜夜夜操| 亚洲电影免费观看高清完整版在线观看| 亚洲欧美偷拍视频| 在线亚洲精品福利网址导航| 国产不卡的av| 亚洲男人天堂2017| 日韩精品xxxx| 欧美熟妇一区二区| 欧美成人a∨高清免费观看| 亚洲欧美日韩国产成人| 国产日韩精品在线看| 手机精品视频在线观看| 国产91在线亚洲| 国产精品最新自拍| 91日韩中文字幕| 中文字幕乱码日本亚洲一区二区| 91午夜视频| 午夜免费福利网站| 国产精品二区一区二区aⅴ| 国产精品对白一区二区三区| 中文在线第一页| 丝袜美腿亚洲一区二区图片| 国产成人一区二区三区影院| 国产日韩在线看| 亚洲一区中文日韩| 精品中文字幕一区二区| 国产伦精品一区二区三区在线观看| 蜜乳av另类精品一区二区| 永久免费未视频| 北条麻妃一区二区三区中文字幕| jizzjizz少妇亚洲水多| 日本国产欧美| 国产寡妇树林野战在线播放| 亚洲无限av看| 国产精品久久久久久久久免费高清| 久久久久久久蜜桃| 啊v视频在线一区二区三区| 成年人小视频在线观看| 亚洲精品在线视频| 国产a视频免费观看| 91探花福利精品国产自产在线| 成人video亚洲精品| 福利视频网站一区二区三区| av在线免费播放网站| 视频一区视频二区国产精品| 国产精品成人99一区无码| 欲香欲色天天天综合和网| 国产精品一区二三区| 亚洲成人av免费看| 全部av―极品视觉盛宴亚洲| av美女在线观看| 一色屋成人免费精品网站| 伊人久久大香线蕉av一区| 91麻豆国产自产在线观看亚洲| 99久久亚洲国产日韩美女| 久久亚洲精品国产亚洲老地址| ass精品国模裸体欣赏pics| 天天躁日日躁狠狠躁伊人| 91精品国产综合久久香蕉| 青青草激情视频| 国产麻豆一级片| 91免费视频播放| 国内成人免费视频| 亚洲男人天堂影院| 国产精品探花一区二区在线观看| 日本v片在线免费观看| 西西444www无码大胆| 精品少妇人妻av一区二区三区| 91久久精品日日躁夜夜躁国产| 三级视频网站在线观看| 欧美性猛交xxxx乱大交退制版| 欧美激情一区二区三区p站| 日本在线视频网址| 久久中文字幕视频| 日本在线视频一区二区三区| 国产精品揄拍500视频| 91嫩草国产在线观看| 国产精品草草| 日韩中文字幕精品| 久久久在线免费观看| 91久久久久国产一区二区| 91黑丝在线观看| 我要看一级黄色大片| 国产视频第一区| 日韩av在线最新| 最近免费中文字幕在线第一页| 午夜精品福利一区二区三区av| av网址在线免费观看| 精品国产鲁一鲁一区二区三区| 九九热最新视频//这里只有精品| 亚洲夜夜综合| 在线一区二区三区做爰视频网站| 欧美男人亚洲天堂| 中文字幕国内精品| 欧美 日韩 国产 成人 在线观看| 欧美国产中文| 可以看av的网站久久看| 国产秒拍福利视频露脸| 久久久影视精品| 真实国产乱子伦对白在线| 国产婷婷色综合av蜜臀av| 日韩欧美在线精品| 一道精品视频一区二区三区男同| 91嫩草国产在线观看| 永久免费看片直接| 国产成人一区二区三区影院在线| 亚洲春色综合另类校园电影| 亚洲乱码精品一二三四区日韩在线| 国产精品亲子伦对白| 欧美日韩你懂得| 青春草在线免费视频| 国产一二三精品| 天天操天天操天天操| 国产精品一区二区免费不卡| 成年人黄视频网站| 超薄肉色丝袜足j调教99| 免费羞羞视频| 怡红院精品视频在线观看极品| 免费裸体视频网站| 久久夜色精品国产欧美乱| 中文字幕不卡在线| 国产99精品国产| 丰满少妇大力进入| 国产精品国产精品国产专区不片| 中文字幕免费在线| 国产乱国产乱老熟300部视频| 久久久久国产精品www| 国产三级自拍| 一区二区精品视频在线观看| 国产精品久久久久7777| 国产精品va在线观看无码| 色婷婷国产精品综合在线观看| 在线视频你懂| 欧美日韩精品欧美日韩精品| 精品无码一区二区三区| 久久人人97超碰国产公开结果| 99蜜月精品久久91| 亚洲三级小视频| 99国产一区二区三精品乱码| 免费极品av一视觉盛宴| 欧美视频在线观看一区二区| 91免费视频播放| 国产精品网站入口| 亚洲熟女乱色一区二区三区久久久| 欧美aaaaaa午夜精品| 浓精h攵女乱爱av| 九色.com| 国产美女av在线| 3d精品h动漫啪啪一区二区| 久久免费国产| 亚洲小视频在线播放| 麻豆视频入口| avove在线播放| 午夜欧美大尺度福利影院在线看| 在线国产精品一区| 欧美日韩综合色| 激情欧美国产欧美| 亚洲一二三四2021不卡| 久久精品视频一区二区| 最新在线黄色网址| 高清毛片在线观看| 波多野结衣a v在线| 国产av麻豆mag剧集| 欧美精品制服第一页| 国产成人aaaa| 亚洲精品在线免费播放| 青青草久久伊人| 狠狠88综合久久久久综合网| 嫩草黄色影院|