reko_3 发表于 2018-10-24 11:00:04

用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
  给脚本加执行权限
  # chmod +x MongoDB_bak.sh
  三、测试
  运行脚本
  # sh +x MongoDB_bak.sh

  在目录下查看

  将数据恢复:
  # mongorestore -h 127.0.0.1:27017 -d cara2 /data/mongodb_bak/mongodb_bak_now/2018_07_25/cara

  进入数据库查看:


  数据正常,说明备份一切都是ok的!
  四、添加定时任务
  # crontab -e
  35 21 * * * /data/mongodb_bak/MongoDB_bak.sh   #每天18:00执行MongoDB数据库备份脚本

页: [1]
查看完整版本: 用shell脚本实现MongoDB数据库自动备份