想要深刻了解MongoDB如何存儲數據以前,有一個概念必須清楚,那就是Memeory-Mapped Files。算法
下圖展現了數據庫是如何跟底層系統打交道的。數據庫
當建立數據庫時(其實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
{ "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 }
{ "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 }
--EOF--app