前言
mongodb的副本集架構(gòu),主庫和從庫的數(shù)據(jù)相同步,如果主庫的機(jī)器壞掉,沒什么關(guān)系,從庫上還有相同的副本數(shù)據(jù)。但如果某人惡意操作或誤操作,一下子批量刪除或drop整個(gè)庫,這樣主庫和從庫的數(shù)據(jù)都會沒有,造成巨大損失。因此,對mongodb數(shù)據(jù)庫定期備份是非常重要的。備份如果每次都全量備份,會消耗大量時(shí)間,并且對 mongodb性能也有影響,從而需要能增量備份。mongodb的增量備份網(wǎng)上沒有現(xiàn)成的工具,故仔細(xì)研究了下寫了個(gè)腳本。
mongodb集群架構(gòu)時(shí),從庫是通過異步復(fù)制主庫的Oplog文件,從而達(dá)到與主庫的同步。
Oplog 記錄了MongoDB數(shù)據(jù)庫的更改操作信息,其保存在local庫的oplog.rs表,在集群架構(gòu)才存在,單機(jī)不會有,故增量備份不能在單機(jī)下使用。 oplog有大小限制,超過指定大小,新的記錄會覆蓋舊的操作記錄。
mongodb增量備份原理
如何將某段時(shí)間的oplog下載下來,我拼接好的例子:
mongodump -h 127.0.0.1 --port 27117 -d local -c oplog.rs -u admin -p xxx --authenticationDatabase admin -q '{ts:{$gt:{$timestamp:{t:1451355000,i:1}},$lt:{$timestamp:{t:1451357430,i:1}}},ns:/^test_db\\./}' -o oplog_backup
上述是導(dǎo)出1451355000-1451357430時(shí)間之間的oplog,導(dǎo)出oplog需要切換到admin權(quán)限賬戶。
原理很簡單,但具體實(shí)現(xiàn)還是需要很多考慮,具體看代碼。腳本在一個(gè)周期內(nèi)(如一星期)先備份一次全量數(shù)據(jù)庫,后面每次進(jìn)行增量備份。腳本地址:http://git.oschina.net/passer/mongodb_backup_script
增量腳本執(zhí)行時(shí)的流程
全量腳本執(zhí)行時(shí)的流程
恢復(fù)時(shí)腳本執(zhí)行的流程
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
標(biāo)簽:興安盟 雞西 自貢 玉林 泰安 廈門 無錫 遼陽
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mongodb增量備份腳本的實(shí)現(xiàn)和原理詳解》,本文關(guān)鍵詞 mongodb,增量,備份,腳本,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。