mongodb增量備份腳本的實現(xiàn)和原理詳解
前言
mongodb的副本集架構(gòu),主庫和從庫的數(shù)據(jù)相同步,如果主庫的機器壞掉,沒什么關(guān)系,從庫上還有相同的副本數(shù)據(jù)。但如果某人惡意操作或誤操作,一下子批量刪除或drop整個庫,這樣主庫和從庫的數(shù)據(jù)都會沒有,造成巨大損失。因此,對mongodb數(shù)據(jù)庫定期備份是非常重要的。備份如果每次都全量備份,會消耗大量時間,并且對 mongodb性能也有影響,從而需要能增量備份。mongodb的增量備份網(wǎng)上沒有現(xiàn)成的工具,故仔細研究了下寫了個腳本。
mongodb集群架構(gòu)時,從庫是通過異步復(fù)制主庫的Oplog文件,從而達到與主庫的同步。
Oplog 記錄了MongoDB數(shù)據(jù)庫的更改操作信息,其保存在local庫的oplog.rs表,在集群架構(gòu)才存在,單機不會有,故增量備份不能在單機下使用。 oplog有大小限制,超過指定大小,新的記錄會覆蓋舊的操作記錄。

mongodb增量備份原理
如何將某段時間的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時間之間的oplog,導(dǎo)出oplog需要切換到admin權(quán)限賬戶。
原理很簡單,但具體實現(xiàn)還是需要很多考慮,具體看代碼。腳本在一個周期內(nèi)(如一星期)先備份一次全量數(shù)據(jù)庫,后面每次進行增量備份。腳本地址:http://git.oschina.net/passer/mongodb_backup_script
增量腳本執(zhí)行時的流程
- 讀取上一個周期執(zhí)行信息判斷是否需要創(chuàng)建新的周期
- 獲得mongodb上oplog最近記錄的時間點current timestamp position
- 從本地讀取上一次執(zhí)行時mongodb的oplog時間點
- dump導(dǎo)出全量數(shù)據(jù)或增量oplog文件到本地,增量oplog文件的導(dǎo)出范圍是 上次oplog記錄點到最新時間內(nèi)的oplog文件
- 保存步驟2獲取的current timestamp position到本地,作為下一次執(zhí)行步驟3中的時間點
- 進行壓縮
- 上傳到oss
- 刪除本地備份文件
全量腳本執(zhí)行時的流程
- 備份mongodb數(shù)據(jù)庫到本地
- 進行壓縮
- 上傳到oss
- 檢驗oss與本地文件的大小是否相同
- 刪除本地備份文件
恢復(fù)時腳本執(zhí)行的流程
- 從oss上下載指定周期的備份文件到本地
- 對全量文件和增量oplog的zip文件進行解壓
- 用 mongorestore對全量文件進行導(dǎo)入
- 用 mongorestore --oplogReplay 分別對各時間段的oplog文件進行導(dǎo)入
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- mongodb增量/全量備份腳本的實現(xiàn)詳解
- mongodb 數(shù)據(jù)庫操作--備份 還原 導(dǎo)出 導(dǎo)入
- MongoDB整庫備份與還原以及單個collection備份、恢復(fù)方法
- MongoDB備份、還原、導(dǎo)出、導(dǎo)入、克隆操作示例
- Windows下自動備份MongoDB的批處理腳本
- Mongodb實現(xiàn)定時備份與恢復(fù)的方法教程
- Windows或Linux系統(tǒng)中備份和恢復(fù)MongoDB數(shù)據(jù)的教程
- Linux下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份詳解
- 淺談MongoDB的備份方式
- MongoDB使用自帶的命令行工具進行備份和恢復(fù)的教程
相關(guān)文章
mongodb 數(shù)據(jù)庫操作詳解--創(chuàng)建,切換,刪除
mongodb是nosql里面最像關(guān)系型數(shù)據(jù)庫的數(shù)據(jù)庫。單表操作,基本上可以和關(guān)系型數(shù)據(jù)庫差不多。mongodb比較易學(xué),易用,分幾期記錄一下,學(xué)習(xí)和使用mongodb過程。2014-07-07
開發(fā)分布式醫(yī)療掛號系統(tǒng)MongoDB集成實現(xiàn)上傳醫(yī)院接口
這篇文章主要介紹了開發(fā)分布式醫(yī)療掛號系統(tǒng)MongoDB集成實現(xiàn)上傳醫(yī)院接口,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-04-04
MongoDB學(xué)習(xí)筆記—Linux下搭建MongoDB環(huán)境
本篇文章主要介紹了Linux下搭建MongoDB環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
MongoDB分片在部署與維護管理中常見的事項總結(jié)大全
分片(sharding)是指將數(shù)據(jù)拆分,將其分散存放在不同的機器上的過程。下面這篇文章主要給大家總結(jié)介紹了關(guān)于MongoDB分片在部署與維護管理中常見事項的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細,需要的朋友可以參考下2018-09-09
mongodb數(shù)據(jù)庫基礎(chǔ)知識之連表查詢
這篇文章主要給大家介紹了關(guān)于mongodb數(shù)據(jù)庫基礎(chǔ)知識之連表查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用mongodb具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06

