a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

MongoDB怎樣對(duì)備份做壓縮操作?

2024-09-07 00:22:31
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
      相信很多人應(yīng)該都有文件、數(shù)據(jù)備份的習(xí)慣,其中MongoDB存儲(chǔ)的數(shù)據(jù)量較大,因此備份文件也是比較大,那么就需要對(duì)MongoDB備份壓縮,下面小編就給大家分享關(guān)于MongoDB實(shí)現(xiàn)備份壓縮的方法,需要的朋友可以參考。
 
      背景及原理                                        
      數(shù)據(jù)庫(kù)的備份是災(zāi)難恢復(fù)的最后一道屏障,不管什么類型的數(shù)據(jù)庫(kù)都需要設(shè)置數(shù)據(jù)庫(kù)備份,MongoDB也不例外。MongoDB 3.0 后 ,數(shù)據(jù)庫(kù)可以采用Wiredtiger存儲(chǔ)引擎后(3.2 版本默認(rèn)),在此環(huán)境下通過(guò)mongodump 備份后,產(chǎn)生的備份文件要遠(yuǎn)大于數(shù)據(jù)存儲(chǔ)文件的大小。此外,一般MongoDB存儲(chǔ)的數(shù)據(jù)量比較大,備份文件也比較大,占用了很多磁盤空間。所以,研究如何實(shí)現(xiàn)MongoDB備份壓縮很有必要。
 
 
 
      上圖是執(zhí)行命令 db.stats() 查看某數(shù)據(jù)庫(kù)的信息。備份文件的大小一般為dataSize的大小,所以我們希望壓縮備份,可以達(dá)到storageSize 或者更小。
 
      一般的備份思路是先備份,后對(duì)備份文件進(jìn)行壓縮。之前,我們采用的就是這種方式,例如主要壓縮命令如下
 
tar -cf - ${targetpath}/${nowtime} | pigz -p 10 > ${targetpath}/${nowtime}.tgz
      (命令解釋: targetpath}/${nowtime 為待壓縮的備份文件;pigz 是Linux壓縮神器,可并行壓縮;-p是指定cpu的核數(shù)。)但是這種方式,生成備份文件的過(guò)程中還是容易形成磁盤性能壓力和空間壓力。下圖為我們某臺(tái)Server 采用先備份后壓縮方式,形成的磁盤可用空間變化。
 
 
 
      真正希望的是在備份的同時(shí)進(jìn)行壓縮,這樣可用空間就比較平穩(wěn)了。在MongoDB 3.2 中 引入了一種壓縮式備份【此mongodb版本必須不低于3.2】。可以使用gzip進(jìn)行壓縮。這是通過(guò)在mongodump和mongorestore中引入一個(gè)新的指令行選項(xiàng)“- -gzip”實(shí)現(xiàn)的。壓縮可用于目錄以及歸檔模型下創(chuàng)建的備份,壓縮還可以減少磁盤空間使用。
 
      測(cè)試
      測(cè)試環(huán)境:
 
測(cè)試服務(wù)器
 
測(cè)試數(shù)據(jù)庫(kù)
 
端口
 
文件路徑
 
172.X.X.245
 
實(shí)例全備
 
17219
 
/data/mongodb_back
 
172.X.X.246
 
QQ_DingDing
 
17218
 
/data/mongodb_back/QQ_DingDing
 
Step 1 壓縮式備份的命令:
 
./mongodump --host 172.X.X.245 --port 17219 -u 用戶名 -p "密碼" --gzip --authenticationDatabase "admin"
--out /data/mongodb_back
      備份后文件的大小,97M。這時(shí)候,查看備份文件的格式都變成了.gz的格式。Step 2 將備份文件copy至遠(yuǎn)程機(jī)器上,進(jìn)行還原:
 
      以下命令是將在172.X.X.246,要求是將文件從X.245 copy至本地
 
scp -r root@172.X.X.245:/data/mongodb_back/QQ_DingDing
      step 3 執(zhí)行還原的命令
 
      執(zhí)行的命令
 
./mongorestore --host 172.X.X.246 --port 17218 -d QQ_DingDing -u 用戶名 -p "密碼"
 --gzip --authenticationDatabase "admin" /data/mongodb_back/QQ_DingDing
      還原后登錄MongoDB,執(zhí)行show dbs,查看此時(shí) 數(shù)據(jù)大小為500M。
 
      補(bǔ)充說(shuō)明
 
      (1)    如果不采用壓縮式的備份,備份后的文件會(huì)是多大呢?備份命令 :
 
./mongodump --host 172.X.X.245 --port 17219 -u 用戶名 -p "密碼" --authenticationDatabase "admin" --out /data/mongodb_back2
      查看此種方法備份后的文件大小--1.5G。以此QQ_DingDing數(shù)據(jù)庫(kù)為例,其壓縮率為(文件壓縮后的大小與壓縮前的大小之比):97M/1.5G=97/1536=6.3%
 
      (2)   這種壓縮備份的方式的會(huì)不會(huì)帶來(lái)一些弊端:例如備份時(shí)間增長(zhǎng)?(恢復(fù)時(shí)間增加?,請(qǐng)自測(cè)一下試試,嘻嘻 @@@)以 某歸檔備份庫(kù)所在實(shí)例為例(storageSize 150G,dataSize 600G )
 
      采用 先備份后壓縮的方式耗時(shí)1小時(shí)55分鐘
 
 
      采用壓縮式備份(指定--gzip參數(shù))的方式耗時(shí) 2小時(shí)33分鐘
 
      產(chǎn)生的備份文件大小基本相等,壓縮式備份方式產(chǎn)生的備份文件略小
 
      所以 壓縮式備份會(huì)導(dǎo)致備份時(shí)間增長(zhǎng)。但從空間使用的角度來(lái)講,我們?nèi)匀唤ㄗh大家使用壓縮式備份,其壓縮比非常高(測(cè)試案例的壓縮比6.3%)。
 
      附:定時(shí)清除,保留7天的紀(jì)錄
 
#!/bin/bash
targetpath='/backup/mongobak'
nowtime=$(date -d '-7 days' "+%Y%m%d")
if [ -d "${targetpath}/${nowtime}/" ]
then
rm -rf "${targetpath}/${nowtime}/"
echo "=======${targetpath}/${nowtime}/===刪除完畢=="
fi
echo "===$nowtime ==="

(編輯:武林網(wǎng))

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产成人在线视频观看 | 九色.com| 欧美高清在线一区 | 一区二区日韩 | 久久天堂av综合合色蜜桃网 | 黄色毛片在线观看 | 国产激情网站 | 人人草人人干 | 美女在线国产 | 一区二区三区在线免费观看 | 国产激情性色视频在线观看 | 成人二区| 美国黄色毛片女人性生活片 | 成人小视频在线观看 | 九九热视频在线 | 精品国产乱码久久久久久久 | 成人片在线播放 | 福利视频一区二区三区 | 国产中文在线 | 黄色片视频免费 | 久久草在线视频 | 国产精选视频 | 在线免费中文字幕 | 成人av影片| 久久草视频 | 999国产 | 一区二区三区久久 | 成人99 | 高清久久| 精品久久一区二区三区 | 国产一区二区三区色淫影院 | 91短视频版在线观看免费大全 | 亚洲电影一区二区三区 | 国产精品久久久久久久久久久久 | 国产一区二区三区久久99 | 在线色网 | 亚洲国产精品一区二区久久 | 视频一区 中文字幕 | 免费一级欧美在线观看视频 | 国产精品久久久久久久久久久久久久 | 国产精品久久一区二区三区 |