MongoDB集羣全備份簡介


MongoDB集羣備份簡介:
mysql

      基於mongodb 副本機+分片的架構進行全庫備份。 
sql

[root@bj02-ops-sto01 scripts]# cat mongodb_backup.sh mongodb

#!/bin/bashbash

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/mysql/bin:/usr/local/mongodb/bin:/usr/local/mongodb/bin架構

export PATHide

export LANG=en_US.utf8spa


Dbip="192.168.100.10"rest

Dport="30000"ip

Datetime=$(date +%Y-%m-%d_%H_%M_%S)cmd

Logfile="/backup/mongodb/mongodbbak_10010/backmongo.log"

Dblist="$(echo 'show dbs'|/usr/local/mongodb/bin/mongo --host ${Dbip} --port ${Dport} |egrep -v "MongoDB|connecting|bye"|awk '{print$1}')"


echo -e "=======start for database backup `date +%F' '%T' '%u`=======\n"  >>$Logfile

backdbcmd(){

echo "$(date) backup $dbname" 

/usr/local/mongodb/bin/mongodump --host ${Dbip} --port ${Dport} --db ${dbname} --out /backup/mongodb/mongodbbak_10010/${Datetime}

echo -e "$(date) Done.\n"

}


for dbname in $Dblist

    do

      echo -e "--------$dbname--------\n" >>$Logfile

      backdbcmd >>$Logfile 2>&1

    done


恢復整個庫:

須要指定上一級目錄,而且刪除config目錄

/usr/local/mongodb/bin/mongorestore  --port=30000 --dir=/home/mongodb/2016-07-28_00_12_05 --writeConcern='{w:0,wtimeout:200}' --numParallelCollections=8 --numInsertionWorkersPerCollection=10 --stopOnError  -v --drop

相關文章
相關標籤/搜索