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

  • 相关阅读:
    LIPS的历史
    语法分析生成器 LEX
    Effective JAVA 中有关Exception的几条建议
    Code Reading chap10
    Code Reading chap8
    Code Reading chap7
    Code Reading chap11
    Code Reading chap9
    软件设计中的抽象层次
    Invalid bound statement (not found) @Update注解写的怎么还报错!
  • 原文地址:https://www.cnblogs.com/ExMan/p/10906863.html
Copyright © 2020-2023  润新知