用shell脚本实现MongoDB数据库自动备份

Posted exman

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用shell脚本实现MongoDB数据库自动备份相关的知识,希望对你有一定的参考价值。

一、创建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

 

给脚本加执行权限

[[email protected] mongodb_bak]# chmod +x MongoDB_bak.sh 

三、测试

运行脚本

[[email protected] mongodb_bak]# sh +x MongoDB_bak.sh 

技术图片

 

在目录下查看

技术图片

 

将数据恢复:

[[email protected] mongodb_bak]# mongorestore -h 127.0.0.1:27017 -d cara2 /data/mongodb_bak/mongodb_bak_now/2018_07_25/cara

技术图片

 

进入数据库查看:

技术图片

 

技术图片

 

数据正常,说明备份一切都是ok的!

 

四、添加定时任务

[[email protected] ~]# crontab -e

35 21 * * * /data/mongodb_bak/MongoDB_bak.sh   #每天18:00执行MongoDB数据库备份脚本

以上是关于用shell脚本实现MongoDB数据库自动备份的主要内容,如果未能解决你的问题,请参考以下文章

用shell脚本自动化备份数据库

shell脚本 每天定时进行自动备份实战脚本~~~

web服务文件更新自动同步数据库主从复制shell脚本实现网站代码备份和mysql备份

使用shell脚本实现自动备份MySQL数据库

使用Shell脚本实现自动备份MySQL数据库

使用Shell脚本实现自动备份MySQL数据库