時間:2024-02-14 10:19作者:下載吧人氣:19
前言
mongodb的副本集架構,主庫和從庫的數據相同步,如果主庫的機器壞掉,沒什么關系,從庫上還有相同的副本數據。但如果某人惡意操作或誤操作,一下子批量刪除或drop整個庫,這樣主庫和從庫的數據都會沒有,造成巨大損失。因此,對mongodb數據庫定期備份是非常重要的。備份如果每次都全量備份,會消耗大量時間,并且對 mongodb性能也有影響,從而需要能增量備份。mongodb的增量備份網上沒有現成的工具,故仔細研究了下寫了個腳本。
mongodb集群架構時,從庫是通過異步復制主庫的Oplog文件,從而達到與主庫的同步。
Oplog 記錄了MongoDB數據庫的更改操作信息,其保存在local庫的oplog.rs表,在集群架構才存在,單機不會有,故增量備份不能在單機下使用。 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
網友評論