内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

如何進(jìn)行mongdb備份恢復(fù)

如何進(jìn)行mongdb備份恢復(fù),針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

目前成都創(chuàng)新互聯(lián)公司已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、成都網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、孝昌網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

一、物理備份(拷貝文件)

#!/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:

物理備份只能全庫恢復(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、全庫恢復(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的寫法不一樣,需要指定復(fù)制集名稱,還有就是加上 --oplog參數(shù),來跟蹤備份時(shí)主庫上發(fā)生的所有寫操作,獲取一個(gè)pointin-time快照,否則備份的狀態(tài)將與集 群中其他節(jié)點(diǎn)不匹配。在恢復(fù)時(shí),還必須創(chuàng)建oplog,并指定--oplogReplay參數(shù)來應(yīng)用這些操作,否則恢復(fù)的成員將不知道從何處開始同步,從 而在某個(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ù)問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

網(wǎng)站標(biāo)題:如何進(jìn)行mongdb備份恢復(fù)
分享網(wǎng)址:http://www.rwnh.cn/article32/jisspc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、用戶體驗(yàn)、企業(yè)建站靜態(tài)網(wǎng)站、ChatGPT、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
新郑市| 景泰县| 澄城县| 通化市| 油尖旺区| 平远县| 南京市| 手机| 章丘市| 胶南市| 郯城县| 镇江市| 大渡口区| 得荣县| 大冶市| 建瓯市| 咸丰县| 永福县| 孝昌县| 澄城县| 承德市| 乐亭县| 万盛区| 茶陵县| 绥滨县| 咸宁市| 周宁县| 康定县| 汶川县| 陇川县| 灵武市| 铜梁县| 阿勒泰市| 和平县| 万载县| 华坪县| 攀枝花市| 遂溪县| 焦作市| 绍兴县| 兰考县|