Linux中MongoDB如何实现远程自动备份详解

2019-01-16 21:15:42丽君

前言

看过上一篇接手老项目的痛——MongoDB学习及集群搭建知道,最近接手了一个后妈养的项目,项目的数据库没有人维护,DBA以各种理由推脱暂时不接,面对裸奔没有备份的数据库,我的内心很焦灼,于是花了点时间把生产环境的自动备份给搞起来。

下面话不多说了,来一起看看详细的介绍吧

一些准备

既然都备份了,为了保险起见,备份与库就不放在同一台服务器上了,于是向运维申请了一台服务器,同时安装好mongo,如果不知道怎么安装mongo的话可以看我的上一篇文章。

安装完之后,首先测试下是否可以远程访问目标mongodb,到安装好mongo的bin目录下

./mongo 10.100.1.101:27017 #目标mongo的ip及端口

然后创建些必要的目录,比如备份文件放在哪个目录之类的。

接下来测试下利用mongodump来备份数据库:

./bin/mongodump --host test/10.100.1.101:27017,10.100.1.102:27017 -d testdb --out /data/temp # test为副本集名称 # 10.100.1.101:27017,10.100.1.102:27017为副本集节点,有多个可以多个 # -d testdb是要备份的库名,不填默认副本集下全部 # --out 保存路径

到这里,mongo的备份已经实现,现在要完成的就是自动啦。

编写脚本

自动定时备份其实就是通过crontab命令来实现啦。但前提是我们需要编写个定时跑的脚本。首先我们新建个脚本:

vi /home/local/mongod_bak.sh

然后编写对应的脚本,脚本上有对应的注释,供大家参考,这里主要做了三个动作,首先是备份,然后将备份的文件压缩,然后只保留最近7天的文件。

#!/bin/bash sourcepath='/home/local/mongodb/bin' #mongodb文件路径 targetpath='/home/local/mongodb_bak' #备份的路径 nowtime=$(date +%Y-%m-%d-%H) replicationname='test' #副本集名 dbname='testdb' #库名 port='27017' #端口 ip1='10.100.1.101' #ip ip2='10.100.1.102' echo "============== start backup ${nowtime} ==============" start() { ${sourcepath}/mongodump --host ${replicationname}/${ip1}:${port},${ip2}:${port} -d ${dbname} --out ${targetpath}/${nowtime} } execute() { start if [ $? -eq 0 ] then echo "back successfully!" else echo "back failure!" fi } if [ ! -d "${targetpath}/${nowtime}/" ] then mkdir ${targetpath}/${nowtime} fi execute echo "============== back end ${nowtime} ==============" echo "============== start zip ${nowtime} ==============" zip -r ${targetpath}/${nowtime}.zip ${targetpath}/${nowtime} rm -rf ${targetpath}/${nowtime} echo "============== zip end ${nowtime} ==============" echo "============== start delete seven days ago back ${nowtime} ==============" find ${targetpath} -type f -mtime +7 -name "*" -exec rm -rf {} ; echo "============== delete end ${nowtime} =============="