溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mongodb增量備份腳本的實(shí)現(xiàn)

發(fā)布時(shí)間:2021-06-03 17:28:12 來源:億速云 閱讀:273 作者:Leah 欄目:MongoDB數(shù)據(jù)庫

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í)現(xiàn)

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í)的流程

  1. 讀取上一個(gè)周期執(zhí)行信息判斷是否需要?jiǎng)?chuàng)建新的周期

  2. 獲得mongodb上oplog最近記錄的時(shí)間點(diǎn)current timestamp position

  3. 從本地讀取上一次執(zhí)行時(shí)mongodb的oplog時(shí)間點(diǎn)

  4. dump導(dǎo)出全量數(shù)據(jù)或增量oplog文件到本地,增量oplog文件的導(dǎo)出范圍是 上次oplog記錄點(diǎn)到最新時(shí)間內(nèi)的oplog文件

  5. 保存步驟2獲取的current timestamp position到本地,作為下一次執(zhí)行步驟3中的時(shí)間點(diǎn)

  6. 進(jìn)行壓縮

  7. 上傳到oss

  8. 刪除本地備份文件

全量腳本執(zhí)行時(shí)的流程

  • 備份mongodb數(shù)據(jù)庫到本地

  • 進(jìn)行壓縮

  • 上傳到oss

  • 檢驗(yàn)oss與本地文件的大小是否相同

  • 刪除本地備份文件

恢復(fù)時(shí)腳本執(zhí)行的流程

  1. 從oss上下載指定周期的備份文件到本地

  2. 對全量文件和增量oplog的zip文件進(jìn)行解壓

  3. 用 mongorestore對全量文件進(jìn)行導(dǎo)入

  4. 用 mongorestore --oplogReplay 分別對各時(shí)間段的oplog文件進(jìn)行導(dǎo)入

關(guān)于mongodb增量備份腳本的實(shí)現(xiàn)問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(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)容。

AI