亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mongodb增量備份腳本的實(shí)現(xiàn)和原理詳解

 更新時(shí)間:2018年09月26日 10:32:54   作者:hxt168  
MongoDB本身不支持增量備份,所以這里介紹我找到的方法,下面這篇文章主要給大家介紹了關(guān)于mongodb增量備份腳本的實(shí)現(xiàn)和原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

mongodb的副本集架構(gòu),主庫和從庫的數(shù)據(jù)相同步,如果主庫的機(jī)器壞掉,沒什么關(guān)系,從庫上還有相同的副本數(shù)據(jù)。但如果某人惡意操作或誤操作,一下子批量刪除或drop整個(gè)庫,這樣主庫和從庫的數(shù)據(jù)都會(huì)沒有,造成巨大損失。因此,對(duì)mongodb數(shù)據(jù)庫定期備份是非常重要的。備份如果每次都全量備份,會(huì)消耗大量時(shí)間,并且對(duì) 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ī)不會(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í)的流程

  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. 對(duì)全量文件和增量oplog的zip文件進(jìn)行解壓
  3. 用 mongorestore對(duì)全量文件進(jìn)行導(dǎo)入
  4. 用 mongorestore --oplogReplay 分別對(duì)各時(shí)間段的oplog文件進(jìn)行導(dǎo)入

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法

    mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法

    這篇文章主要給大家介紹了在mongodb 3.4下遠(yuǎn)程連接認(rèn)證失敗的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-06-06
  • 使用命令方式安裝MongoDB指南(Windows、Linux)

    使用命令方式安裝MongoDB指南(Windows、Linux)

    這篇文章主要介紹了使用命令方式安裝MongoDB指南,本文分別介紹Windows、Linux下使用命令的方式安裝mongodb,需要的朋友可以參考下
    2015-04-04
  • MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例介紹

    MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例介紹

    雖然MongoDB這些年很流行,但筆者之前沒研究過,現(xiàn)在有需求研究這類NoSQL的數(shù)據(jù)庫,是為了驗(yàn)證其是否可被替換,本文給大家介紹MongoDB安裝、基礎(chǔ)操作和聚合實(shí)例詳解,感興趣的朋友一起看看吧
    2024-07-07
  • MongoDB??數(shù)據(jù)模型的設(shè)計(jì)模式及優(yōu)缺點(diǎn)

    MongoDB??數(shù)據(jù)模型的設(shè)計(jì)模式及優(yōu)缺點(diǎn)

    這篇文章主要介紹了MongoDB??數(shù)據(jù)模型的設(shè)計(jì)模式,在實(shí)際開發(fā)中,大多數(shù)性能問題都可以追溯到糟糕的模型設(shè)計(jì),官方也提供分享過文檔模型設(shè)計(jì)的進(jìn)階技巧,這里簡單翻譯記錄一下,需要的朋友可以參考下
    2022-12-12
  • 基于MongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解

    基于MongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解

    下面小編就為大家?guī)硪黄贛ongoDB數(shù)據(jù)庫的數(shù)據(jù)類型和$type操作符詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • CentOS7下安裝MongoDB數(shù)據(jù)庫過程

    CentOS7下安裝MongoDB數(shù)據(jù)庫過程

    大家好,本篇文章主要講的是CentOS7下安裝MongoDB數(shù)據(jù)庫過程,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • MongoDB學(xué)習(xí)筆記—Linux下搭建MongoDB環(huán)境

    MongoDB學(xué)習(xí)筆記—Linux下搭建MongoDB環(huán)境

    本篇文章主要介紹了Linux下搭建MongoDB環(huán)境,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11
  • MongoDb CPU利用率過高問題如何解決

    MongoDb CPU利用率過高問題如何解決

    這篇文章主要介紹了MongoDb CPU利用率過高問題如何解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Linux安裝MongoDB?4.0.3詳細(xì)步驟

    Linux安裝MongoDB?4.0.3詳細(xì)步驟

    這篇文章主要介紹了Linux安裝MongoDB?4.0.3詳細(xì)步驟的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • MongoDB備份和還原的操作指南

    MongoDB備份和還原的操作指南

    MongoDB備份和還原是指將MongoDB數(shù)據(jù)庫中的數(shù)據(jù)和集合備份到另一個(gè)存儲(chǔ)位置,并在需要的時(shí)候恢復(fù)這些備份的過程,備份和還原MongoDB數(shù)據(jù)庫非常重要,本文給大家介紹了MongoDB備份和還原的操作指南,需要的朋友可以參考下
    2024-05-05

最新評(píng)論