您好,登錄后才能下訂單哦!
如何進(jìn)行mongdb備份恢復(fù),針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
一、物理備份(拷貝文件)
#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%Y%m%d") HOST=10.10.17.27 PORT=27000 USER=admin PASSWORD=123456 DATA_DIR="/data/mongodb/navy_db/db" BACKUP_PATH="/data/mongodbbackup/$DATE" date +%Y%m%d%H%M >>/data/log/mongodb_bak.log #第一步鎖表 lock() { echo "db.fsyncLock()"| mongo --host $HOST --port $PORT -u $USER -p $PASSWORD admin } execute() { lock if [ $? -eq 0 ] then echo "mongodb lock successfully!" >>/data/log/mongodb_bak.log else echo "mongodb lock fail!" >>/data/log/mongodb_bak.log fi } execute #第二步備份 back() { rsync -av $DATA_DIR $BACKUP_PATH/ } execute() { back if [ $? -eq 0 ] then echo "mongodb back successfully!" >>/data/log/mongodb_bak.log else echo "mongodb back fail!" >>/data/log/mongodb_bak.log fi } execute #第三部解鎖 unlock() { echo "db.fsyncUnlock()"| mongo --host $HOST --port $PORT -u $USER -p $PASSWORD admin } execute() { unlock if [ $? -eq 0 ] then echo "mongodb unlock successfully!" >>/data/log/mongodb_bak.log else echo "mongodb unlock fail!" >>/data/log/mongodb_bak.log fi } execute #刪除歷史數(shù)據(jù) rm -rf "/data/mongodbbackup/${DEL_DATE}/"
PS:
物理備份只能全庫(kù)恢復(fù),不能恢復(fù)單個(gè)表
恢復(fù)步驟:
1、停止需要恢復(fù)的實(shí)例 2、備份清空/data/mongodb/navy_db/db目錄 3、拷貝/data/mongodbbackup/$DATE下面的所有文件和文件夾到/data/mongodb/navy_db/db目錄 4、chown mongod:mongod /data/mongodb/navy_db/db/ -R 5、啟動(dòng)實(shí)例
二、mongodump備份
#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%Y%m%d") HOST=10.10.17.27:27000 USER=admin PASSWORD=123456 BACKUP_PATH="/backup/mongodbbackup/$DATE" date +%Y%m%d%H%M >>/data/log/mongodb_bak.log start() { mongodump -h $HOST -u $USER -p $PASSWORD -o $BACKUP_PATH } execute() { start if [ $? -eq 0 ] then echo "mongodb back successfully!" >>/data/log/mongodb_bak.log else echo "mongodb back fail!" >>/data/log/mongodb_bak.log fi } execute rm -rf "/backup/mongodbbackup/${DEL_DATE}/"
恢復(fù):
1、全庫(kù)恢復(fù)
mongorestore --host 10.10.17.27 --port 27000 /backup/mongodbbackup/20150818/
2、單集合(表的概念)恢復(fù)
mongorestore --host 10.10.17.27 --port 27001 --db navy_db_new --collection navy_db_table_new /backup/mongodbbackup/20150818/navy_db/navy_db_table.bson
三、復(fù)制集備份
#!/bin/sh DATE=`date +%Y%m%d` DEL_DATE=$(date -d '-30 days' "+%Y%m%d") HOST="dbset/10.10.17.27:27000,10.10.17.26:27000" USER=admin PASSWORD=123456 BACKUP_PATH="/data/mongodbbackup/$DATE" date +%Y%m%d%H%M >>/data/log/mongodb_bak.log start() { mongodump -h $HOST -u $USER -p $PASSWORD --oplog -o $BACKUP_PATH } execute() { start if [ $? -eq 0 ] then echo "mongodb back successfully!" >>/data/log/mongodb_bak.log else echo "mongodb back fail!" >>/data/log/mongodb_bak.log fi } execute rm -rf "/backup/mongodbbackup/${DEL_DATE}/"
PS:
備份復(fù)制集和備份單個(gè)mongodb實(shí)例用mongodump備份的方法差不多,只是host的寫(xiě)法不一樣,需要指定復(fù)制集名稱,還有就是加上 --oplog參數(shù),來(lái)跟蹤備份時(shí)主庫(kù)上發(fā)生的所有寫(xiě)操作,獲取一個(gè)pointin-time快照,否則備份的狀態(tài)將與集 群中其他節(jié)點(diǎn)不匹配。在恢復(fù)時(shí),還必須創(chuàng)建oplog,并指定--oplogReplay參數(shù)來(lái)應(yīng)用這些操作,否則恢復(fù)的成員將不知道從何處開(kāi)始同步,從 而在某個(gè)時(shí)間點(diǎn)上與源服務(wù)器保持一致。
恢復(fù):
1、降復(fù)制集中要恢復(fù)的節(jié)點(diǎn)移除
rs.remove("10.10.17.26:27000")
2、運(yùn)行mongorestore --oplogReplay命令
mongorestore --host 10.10.17.26 --port 27000 --oplogReplay /data/mongodbbackup/20150820/
3、創(chuàng)建oplog
use local db.createCollection("oplog.rs", {"capped" : true, "size" : 10000000})
4、恢復(fù)oplog
mongorestore --host 10.10.17.26 --port 27000 -d local -c oplog.rs /data/mongodbbackup/20150820/oplog.bson
5、將該節(jié)點(diǎn)加入到復(fù)制集
rs.add("10.10.17.26:27000")
關(guān)于如何進(jìn)行mongdb備份恢復(fù)問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。