国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > 建站經(jīng)驗 > 正文

OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題

2019-11-02 16:37:46
字體:
供稿:網(wǎng)友

OpenStack Ceilometer用MongoDB解決占用磁盤空間過大問題

背景:Ceilometer使用MongoDB作為數(shù)據(jù)庫,不斷進行采樣,導(dǎo)致數(shù)據(jù)量膨脹,占用過多的磁盤空間。

知識背景

1.數(shù)據(jù)庫文件類型

1.1. journal 日志文件

跟一些傳統(tǒng)數(shù)據(jù)庫不同,MongoDB的日志文件只是用來在系統(tǒng)出現(xiàn)宕機時候恢復(fù)尚未來得及同步到硬盤的內(nèi)存數(shù)據(jù)。日志文件會存放在一個分開的目錄下面。啟動時候MongoDB會自動預(yù)先創(chuàng)建3個每個為1G的日志文件(初始為空)。

1.2. namespace 表名文件 dbname.ns

這個文件用來存儲整個數(shù)據(jù)庫的集合以及索引的名字。這個文件不大,默認(rèn)16M,可以存儲24000個集合或者索引名以及那些集合和索引在數(shù)據(jù)文件中得具體位置。通過這個文件MongoDB可以知道從哪里去開始尋找或插入集合的數(shù)據(jù)或者索引數(shù)據(jù)。

1.3. 數(shù)據(jù)文件 dbname.0, dbname.1,… dbname.n

MongoDB的數(shù)據(jù)以及索引都存放在一個或者多個MongoDB數(shù)據(jù)文件里。第一個數(shù)據(jù)文件會以“數(shù)據(jù)庫名.0”命名,如 my-db.0。這個文件默認(rèn)大小是64M,在接近用完這個64M之前,MongoDB 會提前生成下一個數(shù)據(jù)文件如my-db.1。數(shù)據(jù)文件的大小會2倍遞增。第二個數(shù)據(jù)文件的大小為128M,第三個為256M。一直到了2G以后就會停止,一直按這個2G這個大小增加新的文件。

2.數(shù)據(jù)庫大小參數(shù)

2.1. dataSize

dataSize是最接近真實數(shù)據(jù)大小的一個參數(shù)。你可以用來檢查你的數(shù)據(jù)有多少。這個大小包括了數(shù)據(jù)庫(或者集合)的每條記錄的總和。注意每條記錄除了BSON文檔外還有header及padding這些額外開銷。所以實際大小會比真正數(shù)據(jù)所占空間會稍大。

2.2. storageSize

這個參數(shù)等于數(shù)據(jù)庫或者某個集合所有用到的Data Extents的總和。注意這個數(shù)字會大于dataSize因為Extent里面會有一些刪除文檔之后留下來的碎片。如果有新插入的文檔小于或等于碎片的大小,MongoDB會重新利用這個碎片來存儲新的文檔。不過在這之前這些碎片將一直會被保留在那里占用空間。由于這個原因,你刪除文檔的時候這個參數(shù)不會變小。

2.3. fileSize

這個參數(shù)只在數(shù)據(jù)庫上有效,指的是實際文件系統(tǒng)中用到的文件的大小。它包括所有的數(shù)據(jù)Extents的總和,索引Extent的總和,以及一些未被分配的空間。之前提到MongoDB會對數(shù)據(jù)庫文件創(chuàng)建時候進行預(yù)分配,例如最小就是64M,哪怕你只有幾百個KB的數(shù)據(jù)。所以這個參數(shù)可能會比實際的數(shù)據(jù)大小會大不少。 這些額外未用空間是用來保證MongoDB可以在新的數(shù)據(jù)寫入時候快速的分配新的Extent,避免引起磁盤空間分配引起的延遲。

解決方案

1.減少預(yù)分配的大小(或禁用預(yù)分配)

從MongoDB的預(yù)分配機制考慮,可以減少預(yù)分配的大小,或者禁用預(yù)分配。但是這種方案是會影響數(shù)據(jù)庫行為的。如果數(shù)據(jù)庫沒有頻繁的大數(shù)據(jù)寫入動作,可以采取這種方案。

2.數(shù)據(jù)壓縮

conpact命令可以對collection進行壓縮,從而減少數(shù)據(jù)量的大小。

db.runCommand({compact:'CollectionName'})

這里需要注意的是:

1)操作進行時,會鎖住當(dāng)前操作的collection;

2)compact命令不會釋放磁盤空間的,但新的磁盤請求會使用整理出來的空間;

3.將數(shù)據(jù)導(dǎo)出再導(dǎo)入

mongodump作用是將數(shù)據(jù)庫導(dǎo)出,mongorestore是將導(dǎo)出的數(shù)據(jù)庫再導(dǎo)入,這個過程中會重建索引,所以如果數(shù)據(jù)庫之前進行過刪除操作,空間沒有釋放,那么導(dǎo)入后,刪除的空間會被釋放。

4.定期刪除不用的數(shù)據(jù)

結(jié)合實際情況,ceilometer采取的sample在有效期過后是可以被消除的。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 子长县| 竹山县| 武宣县| 锡林浩特市| 盈江县| 台北市| 伊吾县| 重庆市| 宁都县| 康保县| 张家界市| 江油市| 盖州市| 广丰县| 青州市| 东平县| 博客| 都兰县| 邛崃市| 巍山| 乐平市| 安达市| 博乐市| 高碑店市| 灵台县| 建湖县| 晴隆县| 岗巴县| 武山县| 缙云县| 兴山县| 杨浦区| 搜索| 石泉县| 婺源县| 中山市| 新竹县| 宽甸| 福贡县| 青铜峡市| 迭部县|