1. 程式人生 > >用shell腳本實現MongoDB數據庫自動備份

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

tab bak 權限 任務 保存 mtime rm -rf .sh 技術分享


一、創建MongoDB備份目錄

用來存放數據

mkdir -p /data/mongodb_bak/mongodb_bak_now

mkdir -p /data/mongodb_bak/mongodb_bak_list

技術分享圖片

二、創建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

技術分享圖片


在目錄下查看

技術分享圖片


將數據恢復:

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



技術分享圖片


進入數據庫查看:

技術分享圖片


技術分享圖片


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


四、添加定時任務

[root@server1 ~]# crontab -e

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


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