用shell腳本實現MongoDB數據庫自動備份


一、創建MongoDB備份目錄

用來存放數據

mkdir -p /data/mongodb_bak/mongodb_bak_now

mkdir -p /data/mongodb_bak/mongodb_bak_list

Screenshot from 2018-07-25 21-40-14.png

二、創建MongoDB數據庫備份腳本

 

#!/bin/bash
#

DUMP=/usr/local/mongodb/bin/mongodump    #mongodump命令路


OUT_DIR=/data/mongodb_bak/mongodb_bak_now    
#臨時備份目錄 

TAR_DIR=/data/mongodb_bak/mongodb_bak_list    
#備份存放路徑 

DATE=`date +%Y_%m_%d`   #獲取當前系統時間 


DB_USER=myadmin    #數據庫賬號 


DB_PASS=******    #數據庫密碼

 

DAYS=20    #DAYS=20代表刪除20天前的備份,即只保留近20天的備份


TAR_BAK="mongodb_bak_$DATE.tar.gz"    
#最終保存的數據庫備份文件 

 

cd $OUT_DIR

 

rm -rf $OUT_DIR/*

 

mkdir -p $OUT_DIR/$DATE

  
$DUMP -h 127.0.0.1:27017 -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" -o $OUT_DIR/$DATE   
#備份全部數據庫


tar -zcvf $TAR_DIR/$TAR_BAK $
OUT_DIR/$DATE    #壓縮為.tar.gz格式

 

find $TAR_DIR/ -mtime +$DAYS -delete   #刪除20天前的備份文件

 

exit

 

給腳本加執行權限

[root@server1 mongodb_bak]# chmod +x MongoDB_bak.sh 

三、測試

運行腳本

[root@server1 mongodb_bak]# sh +x MongoDB_bak.sh 

Screenshot from 2018-07-25 22-10-27.png

 

在目錄下查看

Screenshot from 2018-07-25 22-11-35.png

 

將數據恢復:

[root@server1 mongodb_bak]# mongorestore -h 127.0.0.1:27017 -d cara2 /data/mongodb_bak/mongodb_bak_now/2018_07_25/cara

Screenshot from 2018-07-25 22-13-27.png

 

進入數據庫查看:

Screenshot from 2018-07-25 22-15-46.png

 

Screenshot from 2018-07-25 22-15-51.png

 

數據正常,說明備份一切都是ok的!

 

四、添加定時任務

[root@server1 ~]# crontab -e

35 21 * * * /data/mongodb_bak/MongoDB_bak.sh   #每天18:00執行MongoDB數據庫備份腳本


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM