版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lazycheerup/article/details/85203466
一.MongoDB数据备份
在Mongodb中我们使用mongodump命令来备份MongoDB数据。该命令可以导出所有数据到指定目录中。
mongodump命令可以通过参数指定导出的数据量级转存的服务器。
>mongodump -h dbhost -d dbname -o dbdirectory
参数解释:
- -h:
MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
- -d:
需要备份的数据库实例,例如:test
- -o:
备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。
以下是shell脚本(请替换以下脚本的 数据库名称、数据库账号、数据库密码):
#!/bin/sh
#备份Mongo 数据库:
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
echo "1.初始化。。。。。"
export PATH
bakDir="/mnt/mongodb_bak/h77"
dbName="数据库名称"
fileName=$dbName"`date +%Y%m%d`.tar"
timeStr="`date +%Y%m%d`"
realDbBakDir=$bakDir/$timeStr
if [ ! -x "$bakDir" ];then
mkdir $bakDir
fi
cd $bakdir
echo "备份的数据库为:" $dbName
echo "备份目录为:" $bakDir
echo $dbName "数据库备份文件目录为:" $realDbBakDir
echo "2.备份开始:"
mongodump -h 127.0.0.1:27017 -u '数据库账号' -p '数据库密码' -d $dbName -o $realDbBakDir
echo "3.备份结束,开始打包"
for((i=1;i<10;i++))
do
echo "当前等待时间" $i "秒"
sleep 1
done
echo "备份文件:" $realDbBakDir/$dbName/$fileName
tar -czvf $realDbBakDir/$fileName $realDbBakDir/$dbName/
echo "4.打包完成,开始scp上传"
#scp $realDbBakDir/$fileName root@h121:/mnt/mongobak/h77/
echo "5.上传成功"
echo "备份成功日志`date`" >> bak.log
脚本解释:
1.如果需要把备份好的文件通过scp 命令上传到其他服务器,请放开以下注释,并合理替换
scp $realDbBakDir/$fileName root@h121:/mnt/mongobak/h77/
a.h121 是远程服务器的别名(可以修改 /etc/hosts hosts文件是linux系统中负责ip地址与域名快速解析的文件)
b./mnt/mongobak/h77/ 是远程服务器的存放备份文件的路径(如果没有远程目录,请先创建)
c.备份数据库文件需要时间,所以我sleep一段10秒,然后再压缩文件
for((i=1;i<10;i++))
do
echo "当前等待时间" $i "秒"
sleep 1
done
d.本地服务器存放的目录为:bakDir="/mnt/mongodb_bak/h77" ,你们可以自己修改;