Linux下MongoDB数据库实现自动备份详解
程序员文章站
2022-03-23 22:13:36
本文主要给大家介绍的是关于linux下mongodb数据库实现自动备份的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:
一、创建mongodb备份目录...
本文主要给大家介绍的是关于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参数:后面跟要恢复的数据库名称
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。