婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 深入了解MongoDB是如何存儲數據的

深入了解MongoDB是如何存儲數據的

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

前言

本文主要介紹了關于MongoDB存儲數據的相關內容,分享出來供大家參考學習,下面來一起看看詳細的介紹:

想要深入了解MongoDB如何存儲數據之前,有一個概念必須清楚,那就是Memeory-Mapped Files。

Memeory-Mapped Files

下圖展示了數據庫是如何跟底層系統打交道的。

  • 內存映射文件是OS通過mmap在內存中創建一個數據文件,這樣就把文件映射到一個虛擬內存的區域。
  • 虛擬內存對于進程來說,是一個物理內存的抽象,尋址空間大小為2^64
  • 操作系統通過mmap來把進程所需的所有數據映射到這個地址空間(紅線),然后再把當前需要處理的數據映射到物理內存(灰線)
  • 當進程訪問某個數據時,如果數據不在虛擬內存里,觸發page fault,然后OS從硬盤里把數據加載進虛擬內存和物理內存
  • 如果物理內存滿了,觸發swap-out操作,這時有些數據就需要寫回磁盤,如果是純粹的內存數據,寫回swap分區,如果不是就寫回磁盤。

MongoDB的存儲模型

  • 有了內存映射文件,要訪問的數據就好像都在內存里面,簡單化了MongoDB訪問和修改數據的邏輯
  • MongoDB讀寫都只是和虛擬內存打交道,剩下都交給OS打理
  • 虛擬內存大小=所有文件大小+其他一些開銷(連接,堆棧)
  • 如果journal開啟,虛擬內存大小差不多翻番
  • 使用MMF的好處1:不用自己管理內存和磁盤調度2:LRU策略3:重啟過程中,Cache依然在。
  • 使用MMF的壞處1:RAM使用會受磁盤碎片的影響,高預讀也會影響2:無法自己優化調度算法,只能使用LRU

  • 磁盤上的文件是有extent構成,分配集合空間的時候也是以extent為單位進行分配的
  • 一個集合有一個或者多個etent
  • ns文件里面命名空間記錄指向那個集合的第一個extent

數據文件與空間分配

當創建數據庫時(其實MongoDB沒有顯式創建數據庫的方法,在向數據庫中的集合寫入數據時會自動創建該數據庫),MongoDB會在磁盤上分配一組數據文件,所有集合,索引和數據庫的其他元數據都保存在這些文件里。數據文件被放在啟動時指定的dbpath里,默認放入/data/db下面。典型的一個文件組織結構如下:

$ cat /data/db
$ ls -al
-rw------- 1 root root 16777216 09-18 00:54 local.ns
-rw------- 1 root root 67108864 09-18 00:54 local.0
-rw------- 1 root root 2146435072 09-18 00:55 local.1
-rw------- 1 root root 2146435072 09-18 00:56 local.2
-rw------- 1 root root 2146435072 09-18 00:57 local.3
-rw------- 1 root root 2146435072 09-18 00:58 local.4
-rw------- 1 root root 2146435072 09-18 00:59 local.5
-rw------- 1 root root 2146435072 09-18 01:01 local.6
-rw------- 1 root root 2146435072 09-18 01:02 local.7
-rw------- 1 root root 2146435072 09-18 01:03 local.8
-rw------- 1 root root 2146435072 09-18 01:04 local.9
-rw------- 1 root root 2146435072 09-18 01:05 local.10
-rw------- 1 root root 16777216 09-18 01:06 test.ns
-rw------- 1 root root 67108864 09-18 01:06 test.0
-rw------- 1 root root 134217728 09-18 01:06 test.1
-rw------- 1 root root 268435456 09-18 01:06 test.2
-rw------- 1 root root 536870912 09-18 01:06 test.3
-rw------- 1 root root 1073741824 09-18 01:07 test.4
-rw------- 1 root root 2146435072 09-18 01:07 test.5
-rw------- 1 root root 2146435072 09-18 01:09 test.6
-rw------- 1 root root 2146435072 09-18 01:11 test.7
-rw------- 1 root root 2146435072 09-18 01:13 test.8
...
-rwxr-xr-x 1 root root  6 09-18 13:54 mongod.lock
drwxr-xr-x 2 root root 4096 11-13 18:39 journal
drwxr-xr-x 2 root root 4096 11-13 19:02 _tmp
  • mongod.lock中存儲了服務器的進程ID,是一個進程鎖定文件。數據文件是依據所屬的數據庫命名的。
  • test.ns是第一個生成的文件(ns擴展名就是namespace的意思),數據庫中的每個集合和索引都有自己的命名空間,每個命名空間的元數據都存放在這個文件里。默認情況下,.ns文件大小固定在16MB,大約可以存儲24000個命名空間。也就是說數據庫中的索引和集合總數不能超過24000,該值可以通過mongod的–nssize選項進行定制。
  • 像test.0這樣以0開始的整數結尾的文件就是集合和索引數據文件。剛開始的時候,即使只有一條數據,MongoDB也會預分配幾個文件,這種預分配的做法,能讓數據盡可能連續存儲,減少磁盤碎片。在像數據庫添加數據時,MongoDB會分配更多的數據文件。每個新數據文件的大小都是上一個已分配文件的兩倍(64M->128M->256M),直到預分配文件大小的上限2G。此處基于一個假設,如果總數據大小呈恒定速率增長,應該逐漸增加數據文件分配的空間。當然這個預分配策略也是可以通過–noprealloc關掉,但是不建議在production環境下使用。
  • 默認的local數據庫,該數據庫不參與replication。當mongod是一個副本集的成員時,在local數據庫中就有一個叫做oplog.rs的預分配的capped集合,預分配的大小為磁盤空間的5%。這個大小可以通過–oplogSize進行調整。oplog主要用于副本集Primary和Secondary成員見的replication,它的大小限制了兩個副本集之間,在重新完全同步之前,允許多長時間不同步。
  • journal目錄,journal功能2.4版本默認是開啟的。
  • 可以使用db.stats()來確認已使用空間和已分配空間。
{
 "db" : "test",
 "collections" : 37,
 "objects" : 317894523, #文檔總個數
 "avgObjSize" : 232.3416429039893, #單位是字節
 "dataSize" : 73860135744, #集合中所有數據實際大小(包括padding factor為每個文檔分配的額外空間以允許文檔增長)。該值在文檔size變小的時候,這個值不會減少,除非文檔被刪除,或者執行compact或者repairDatabase操作
 "storageSize" : 97834319392, #分配給集合的空間大小(包括為集合增長預留的額外空間和未分配的已刪除空間,即不會因為文檔size變小或者刪除而減小),實際上從數據文件中分配給集合的空間是以塊為單位,也稱之為extents,即分配的extents的大小
 "numExtents" : 385,
 "indexes" : 86,
 "indexSize" : 58687466992,
 "fileSize" : 182380920832, #所有數據文件大小之和,不包括命名空間文件(ns文件)
 "nsSizeMB" : 16,
 "dataFileVersion" : {
 "major" : 4,
 "minor" : 5
 },
 "ok" : 1
}

使用db.accesslog.stats()確認某個集合的使用量

{
 "ns" : "test.accesslog",
 "count" : 145352932,
 "size" : 37060264352, #實際數據大小,不包括索引
 "avgObjSize" : 254.967435758365,
 "storageSize" : 45794676448, #預分配的數據存儲空間
 "numExtents" : 42,
 "nindexes" : 4,
 "lastExtentSize" : 2146426864,
 "paddingFactor" : 1, #當文檔因更新size增長時事先padding可以提速,減少碎片的產生
 "systemFlags" : 1,
 "userFlags" : 0,
 "totalIndexSize" : 31897944512,
 "indexSizes" : {
 "_id_" : 6722168208,
 "action_1_time_1" : 8606482752,
 "gz_id_1_action_1_time_1" : 10753778336,
 "time_1" : 5815515216
 },
 "ok" : 1
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • MongoDB系列教程(八):GridFS存儲詳解
  • PHP操作MongoDB GridFS 存儲文件的詳解
  • PHP MongoDB GridFS 存儲文件的方法詳解
  • Spring Boot集成Shiro并利用MongoDB做Session存儲的方法詳解
  • Nodejs使用Mongodb存儲與提供后端CRD服務詳解
  • python將MongoDB里的ObjectId轉換為時間戳的方法
  • python根據時間生成mongodb的ObjectId的方法
  • 深究從MongoDB的ObjectId中獲取時間信息
  • MongoDB批量將時間戳轉為通用日期格式示例代碼
  • MongoDB存儲時間時差問題的解決方法

標簽:廈門 泰安 遼陽 自貢 無錫 玉林 雞西 興安盟

巨人網絡通訊聲明:本文標題《深入了解MongoDB是如何存儲數據的》,本文關鍵詞  深入,了解,MongoDB,是,如何,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入了解MongoDB是如何存儲數據的》相關的同類信息!
  • 本頁收集關于深入了解MongoDB是如何存儲數據的的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美xxxxxxxx| 欧美日韩一级片网站| 老鸭窝一区二区久久精品| 国产盗摄视频一区二区三区| 国产午夜精品美女毛片视频| 夜夜精品视频一区二区| 日韩精品一区二区三区中文精品| 中文字幕欧美国产| 狠狠色综合日日| 欧美日韩精品一区二区三区蜜桃 | 欧美大片一区二区| 天天色天天操综合| 欧美日韩国产综合视频在线观看 | 亚洲一卡二卡三卡四卡五卡| 91同城在线观看| 亚洲欧美综合网| 欧美三级日韩三级国产三级| 婷婷六月综合网| 26uuu精品一区二区在线观看| 国产精品亚洲视频| 亚洲视频图片小说| 欧美精品vⅰdeose4hd| 久久综合综合久久综合| 国产视频亚洲色图| 一二三区精品视频| 欧美不卡在线视频| 国产成人8x视频一区二区| 久久激情综合网| 亚洲一区二区在线播放相泽| 日韩欧美一区二区不卡| 色婷婷久久久久swag精品| 麻豆精品视频在线| 丝袜美腿亚洲一区二区图片| 亚洲欧美另类图片小说| 国产精品理伦片| 精品国产3级a| 884aa四虎影成人精品一区| 色94色欧美sute亚洲线路一ni | 亚洲在线免费播放| 国产一区二区影院| 婷婷中文字幕综合| 欧美精品高清视频| 极品少妇一区二区三区精品视频| 处破女av一区二区| 一区二区三区美女| 欧美成人综合网站| 国产一区二区免费看| 中文字幕精品综合| 在线精品视频一区二区| 偷窥国产亚洲免费视频| 日韩女优av电影在线观看| 国产精品99久久久久久宅男| 中文字幕av不卡| 日韩三级高清在线| 91麻豆精品在线观看| 久久精品国产一区二区三| 成人免费在线播放视频| 色综合久久综合网| 亚洲一区二区三区精品在线| 日韩区在线观看| 91高清在线观看| 成人网男人的天堂| 北条麻妃一区二区三区| 久久精品国产77777蜜臀| 国产精品久99| 欧美欧美欧美欧美| 在线观看欧美日本| 在线视频国内一区二区| 国产不卡在线一区| 国模套图日韩精品一区二区| 青青草原综合久久大伊人精品| 亚洲国产sm捆绑调教视频 | 欧美日韩久久久| 欧美日本一道本| 欧美日韩不卡一区二区| 欧美色图激情小说| 久久99精品国产麻豆婷婷洗澡| 亚洲成人av免费| 国产九九视频一区二区三区| 成人aaaa免费全部观看| 国产盗摄精品一区二区三区在线 | 粉嫩一区二区三区在线看| 国产高清亚洲一区| 中文av字幕一区| 亚洲自拍偷拍网站| 日韩—二三区免费观看av| 成人精品视频一区| 欧美日韩亚洲综合在线| 色婷婷综合久久久久中文一区二区| 欧美综合视频在线观看| 欧美tickling网站挠脚心| 国产精品久久久久久久久果冻传媒 | 91在线你懂得| 久久国产剧场电影| 99国内精品久久| 久久久久国产精品麻豆ai换脸 | 日韩电影在线看| 99热99精品| 久久久99精品免费观看不卡| 日韩影院精彩在线| 成人av中文字幕| 欧美电视剧在线看免费| 国产精品美女久久久久aⅴ| 午夜精品久久久久久久久| 99国内精品久久| 亚洲欧洲av一区二区三区久久| 精品在线免费视频| 国产丝袜美腿一区二区三区| 韩国三级在线一区| 精品国内二区三区| 国产精品亚洲第一| 国产三级精品三级| 国产v综合v亚洲欧| 亚洲天堂2014| 9191精品国产综合久久久久久| 日韩电影在线观看电影| 欧美日韩精品一二三区| 日韩国产在线观看一区| 精品日韩欧美在线| 国产一区二区三区在线观看免费视频| 制服丝袜成人动漫| 国产做a爰片久久毛片| 欧美另类videos死尸| 日本v片在线高清不卡在线观看| 日韩午夜小视频| 欧美人妇做爰xxxⅹ性高电影 | 91美女蜜桃在线| 日韩av网站免费在线| 中文一区一区三区高中清不卡| 欧美日韩在线观看一区二区 | 精品久久一二三区| 91视频在线看| 国产一区二区精品久久91| 一区二区三区精品久久久| 精品国产露脸精彩对白| 欧美美女直播网站| 94-欧美-setu| 成人国产电影网| 国产精品自拍毛片| 久久av老司机精品网站导航| 中文字幕精品三区| 精品免费日韩av| 精品一区二区三区视频| 欧美丝袜丝nylons| 成人欧美一区二区三区小说| 丁香桃色午夜亚洲一区二区三区| 欧美自拍偷拍午夜视频| 中文字幕av不卡| av网站一区二区三区| 中文幕一区二区三区久久蜜桃| 久久精品国产精品青草| 精品欧美乱码久久久久久1区2区| 一区二区成人在线| 欧美卡1卡2卡| 日韩电影在线看| 精品久久久久久久久久久久包黑料| 蜜桃精品视频在线观看| 精品国产乱码久久久久久浪潮| 精品一区免费av| 国产欧美一区在线| 色婷婷av一区二区三区大白胸| 性做久久久久久| 欧美精彩视频一区二区三区| fc2成人免费人成在线观看播放| 亚洲区小说区图片区qvod| 色综合 综合色| 久久国产精品99久久久久久老狼| 久久综合九色综合欧美亚洲| 波多野结衣91| 三级在线观看一区二区| 欧美激情一区二区三区蜜桃视频| 97精品超碰一区二区三区| 奇米色一区二区| 亚洲精品大片www| 久久久久97国产精华液好用吗 | 欧美韩日一区二区三区| 在线电影一区二区三区| 成人h动漫精品一区二区| 欧美bbbbb| 秋霞av亚洲一区二区三| 亚洲一区二区三区在线看| 中文字幕一区二区在线播放| 久久天堂av综合合色蜜桃网| 欧美高清精品3d| 亚洲欧洲综合另类| 精品成人佐山爱一区二区| 欧美一区二区三区的| 欧美午夜精品免费| 色美美综合视频| 在线视频观看一区| 欧美亚洲国产怡红院影院| 欧美性受xxxx| 欧美一区二区成人6969| 日韩欧美国产综合在线一区二区三区| 欧美日韩在线亚洲一区蜜芽| 6080日韩午夜伦伦午夜伦| 日韩无一区二区| 久久久高清一区二区三区| 国产精品另类一区| 亚洲永久精品大片|