加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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

发布时间:2020-12-15 19:09:15 所属栏目:安全 来源:网络整理
导读:一、创建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备份目录

用来存放数据

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数据库备份脚本

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读