码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-07-25 22:43:03      阅读:347      评论:0      收藏:0      [点我收藏+]

标签:chmod   ber   database   数据库密码   lis   str   server1   func   ges   


一、创建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数据库自动备份

标签:chmod   ber   database   数据库密码   lis   str   server1   func   ges   

原文地址:http://blog.51cto.com/13362895/2150200

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!