当前位置: 移动技术网 > IT编程>数据库>MongoDB > Linux下MongoDB数据库实现自动备份详解

Linux下MongoDB数据库实现自动备份详解

2017年12月08日  | 移动技术网IT编程  | 我要评论

恒金棒,栾义军,新能源龙头股

本文主要给大家介绍的是关于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_bak_list 
#获取当前系统时间 
date=`date +%y_%m_%d` 
#数据库账号 
db_user=user 
#数据库密码 
db_pass=123 
#days=15代表删除15天前的备份,即只保留近15天的备份 
days=15 
#最终保存的数据库备份文件 
tar_bak="mongodb_bak_$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 20 * * 6 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参数:后面跟要恢复的数据库名称

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网