q789321 发表于 2018-10-25 06:39:22

Linux下MongoDB自动备份

  一、创建MongoDB备份目录
  mkdir -p /data/mongodb_bak/mongodb_bak_now
  mkdir -p /data/mongodb_bak/mongodb_bak_list
  二、新建MongoDB数据库备份脚本(/data/mongodb_bak/MongoDB_bak.sh)
  #!/bin/bash
  #backup MongoDB
  #mongodump命令路径
  DUMP=/usr/local/mongodb/bin/mongodump
  #临时备份目录
  OUT_DIR=/data/mongodb_bak/mongodb_bak_now
  #备份存放路径
  TAR_DIR=/data/mongodb_bak/mongodb_baklist
  #获取当前系统时间
  DATE=`date +%Y%m_%d`
  #数据库账号
  DB_USER=user
  #数据库密码
  DB_PASS=123
  #DAYS=15代表删除15天前的备份,即只保留近15天的备份
  DAYS=15
  #最终保存的数据库备份文件
  TAR_BAK="mongodbbak$DATE.tar.gz"
  cd $OUT_DIR
  rm -rf $OUT_DIR/*
  mkdir -p $OUT_DIR/$DATE
  #备份全部数据库
  $DUMP -h 15.62.32.112:27017 -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" -o $OUT_DIR/$DATE
  #压缩为.tar.gz格式
  tar -zcvf $TAR_DIR/$TAR_BAK $OUT_DIR/$DATE
  #删除15天前的备份文件
  find $TAR_DIR/ -mtime +$DAYS -delete
  exit
  三、修改文件属性,使其可执行
  chmod +x MongoDB_bak.sh
  四、修改/etc/crontab,添加计划任务
  vi /etc/crontab
  #每星期六晚上20:30开始执行MongoDB数据库备份脚本
  30 206 root /data/mongodb_bak/MongoDB_bak.sh
  附录:MongoDB数据库恢复
  #恢复全部数据库
  mongorestore -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" --noIndexRestore --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/
  #恢复单个数据库
  mongorestore -u $DB_USER -p $DB_PASS --authenticationDatabase "admin" --noIndexRestore -d dbname --dir /data/mongodb_bak/mongodb_bak_now/2016_12_17/dbname
  部分参数说明
  --drop参数:恢复数据之前删除原来的数据,避免数据重复
  --noIndexRestore参数:恢复数据时不创建索引
  --dir参数:数据库备份目录
  -d参数:后面跟要恢复的数据库名称

页: [1]
查看完整版本: Linux下MongoDB自动备份