您好,登錄后才能下訂單哦!
mongodb增量備份腳本的實(shí)現(xiàn)?針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。
mongodb集群架構(gòu)時(shí),從庫是通過異步復(fù)制主庫的Oplog文件,從而達(dá)到與主庫的同步。
Oplog 記錄了MongoDB數(shù)據(jù)庫的更改操作信息,其保存在local庫的oplog.rs表,在集群架構(gòu)才存在,單機(jī)不會(huì)有,故增量備份不能在單機(jī)下使用。 oplog有大小限制,超過指定大小,新的記錄會(huì)覆蓋舊的操作記錄。
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í)的流程
讀取上一個(gè)周期執(zhí)行信息判斷是否需要?jiǎng)?chuàng)建新的周期
獲得mongodb上oplog最近記錄的時(shí)間點(diǎn)current timestamp position
從本地讀取上一次執(zhí)行時(shí)mongodb的oplog時(shí)間點(diǎn)
dump導(dǎo)出全量數(shù)據(jù)或增量oplog文件到本地,增量oplog文件的導(dǎo)出范圍是 上次oplog記錄點(diǎn)到最新時(shí)間內(nèi)的oplog文件
保存步驟2獲取的current timestamp position到本地,作為下一次執(zhí)行步驟3中的時(shí)間點(diǎn)
進(jìn)行壓縮
上傳到oss
刪除本地備份文件
全量腳本執(zhí)行時(shí)的流程
備份mongodb數(shù)據(jù)庫到本地
進(jìn)行壓縮
上傳到oss
檢驗(yàn)oss與本地文件的大小是否相同
刪除本地備份文件
恢復(fù)時(shí)腳本執(zhí)行的流程
從oss上下載指定周期的備份文件到本地
對全量文件和增量oplog的zip文件進(jìn)行解壓
用 mongorestore對全量文件進(jìn)行導(dǎo)入
用 mongorestore --oplogReplay 分別對各時(shí)間段的oplog文件進(jìn)行導(dǎo)入
關(guān)于mongodb增量備份腳本的實(shí)現(xiàn)問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。