如何進行mongdb備份恢復,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
成都網絡公司-成都網站建設公司創(chuàng)新互聯十多年經驗成就非凡,專業(yè)從事網站設計、網站建設,成都網頁設計,成都網頁制作,軟文推廣,廣告投放平臺等。十多年來已成功提供全面的成都網站建設方案,打造行業(yè)特色的成都網站建設案例,建站熱線:028-86922220,我們期待您的來電!一、物理備份(拷貝文件)
#!/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 #刪除歷史數據 rm -rf "/data/mongodbbackup/${DEL_DATE}/"PS:
物理備份只能全庫恢復,不能恢復單個表
恢復步驟:
1、停止需要恢復的實例 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、啟動實例二、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}/"恢復:
1、全庫恢復
mongorestore --host 10.10.17.27 --port 27000 /backup/mongodbbackup/20150818/2、單集合(表的概念)恢復
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三、復制集備份
#!/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:
備份復制集和備份單個mongodb實例用mongodump備份的方法差不多,只是host的寫法不一樣,需要指定復制集名稱,還有就是加上 --oplog參數,來跟蹤備份時主庫上發(fā)生的所有寫操作,獲取一個pointin-time快照,否則備份的狀態(tài)將與集 群中其他節(jié)點不匹配。在恢復時,還必須創(chuàng)建oplog,并指定--oplogReplay參數來應用這些操作,否則恢復的成員將不知道從何處開始同步,從 而在某個時間點上與源服務器保持一致。
恢復:
1、降復制集中要恢復的節(jié)點移除
rs.remove("10.10.17.26:27000")2、運行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、恢復oplog
mongorestore --host 10.10.17.26 --port 27000 -d local -c oplog.rs /data/mongodbbackup/20150820/oplog.bson5、將該節(jié)點加入到復制集
rs.add("10.10.17.26:27000")關于如何進行mongdb備份恢復問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯行業(yè)資訊頻道了解更多相關知識。
另外有需要云服務器可以了解下創(chuàng)新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。