Linux下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份詳解
本文主要給大家介紹的是關(guān)于Linux下MongoDB數(shù)據(jù)庫實現(xiàn)自動備份的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面來一起看看詳細(xì)的介紹:
一、創(chuàng)建MongoDB備份目錄
mkdir -p /data/mongodb_bak/mongodb_bak_now mkdir -p /data/mongodb_bak/mongodb_bak_list
二、新建MongoDB數(shù)據(jù)庫備份腳本(/data/mongodb_bak/MongoDB_bak.sh)
#!/bin/bash #backup MongoDB #mongodump命令路徑 DUMP=/usr/local/mongodb/bin/mongodump #臨時備份目錄 OUT_DIR=/data/mongodb_bak/mongodb_bak_now #備份存放路徑 TAR_DIR=/data/mongodb_bak/mongodb_bak_list #獲取當(dāng)前系統(tǒng)時間 DATE=`date +%Y_%m_%d` #數(shù)據(jù)庫賬號 DB_USER=user #數(shù)據(jù)庫密碼 DB_PASS=123 #DAYS=15代表刪除15天前的備份,即只保留近15天的備份 DAYS=15 #最終保存的數(shù)據(jù)庫備份文件 TAR_BAK="mongodb_bak_$DATE.tar.gz" cd $OUT_DIR rm -rf $OUT_DIR/* mkdir -p $OUT_DIR/$DATE #備份全部數(shù)據(jù)庫 $DUMP -h 15.62.32.112:27017 -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" -o $OUT_DIR/$DATE #壓縮為.tar.gz格式 tar -zcvf $TAR_DIR/$TAR_BAK $OUT_DIR/$DATE #刪除15天前的備份文件 find $TAR_DIR/ -mtime +$DAYS -delete exit
三、修改文件屬性,使其可執(zhí)行
chmod +x MongoDB_bak.sh
四、修改/etc/crontab,添加計劃任務(wù)
vi /etc/crontab #每星期六晚上20:30開始執(zhí)行MongoDB數(shù)據(jù)庫備份腳本 30 20 * * 6 root /data/mongodb_bak/MongoDB_bak.sh
附錄:MongoDB數(shù)據(jù)庫恢復(fù)
#恢復(fù)全部數(shù)據(jù)庫 mongorestore -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" --noIndexRestore --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/ #恢復(fù)單個數(shù)據(jù)庫 mongorestore -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" --noIndexRestore -d dbname --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/dbname
部分參數(shù)說明
- --drop參數(shù):恢復(fù)數(shù)據(jù)之前刪除原來的數(shù)據(jù),避免數(shù)據(jù)重復(fù)
- --noIndexRestore參數(shù):恢復(fù)數(shù)據(jù)時不創(chuàng)建索引
- --dir參數(shù):數(shù)據(jù)庫備份目錄
- -d參數(shù):后面跟要恢復(fù)的數(shù)據(jù)庫名稱
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
MongoDB學(xué)習(xí)筆記之分組(group)使用示例
這篇文章主要介紹了MongoDB學(xué)習(xí)筆記之分組(group)使用示例,本文直接給出一組測試數(shù)據(jù),然后練習(xí)分組的基本使用,需要的朋友可以參考下2015-07-07關(guān)于CentOS 8 搭建MongoDB4.4分片集群的問題
在MongoDB里面存在另一種集群,就是分片技術(shù),可以滿足MongoDB數(shù)據(jù)量大量增長的需求。這篇文章主要介紹了CentOS 8 搭建MongoDB4.4分片集群的問題,需要的朋友可以參考下2021-10-10SpringBoot+MongoDB實現(xiàn)物流訂單系統(tǒng)的代碼
這篇文章主要介紹了SpringBoot+MongoDB實現(xiàn)物流訂單系統(tǒng)的代碼,本文通過圖文實例相結(jié)合給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作
這篇文章主要介紹了Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的問題及操作方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03