Windows或Linux系統(tǒng)中備份和恢復(fù)MongoDB數(shù)據(jù)的教程
windows下面mongodb數(shù)據(jù)庫備份和恢復(fù)
我可以講數(shù)據(jù)備份到c:\data\dump目錄下面,首先創(chuàng)建這個(gè)路徑。然后進(jìn)入到mongodb的bin目錄下面
我的是:
C:\Program Files\mongodb\bin
備份腳本是:
//備份 mongodump -h 127.0.0.1:27017 -d test -o c:\data\dump
恢復(fù)腳本是:
//恢復(fù) mongorestore -h 127.0.0.1:27017 -d test --directoryperdb c:\data\dump\test
解釋一下用到的命令
- -h:MongoDB所在服務(wù)器地址
- -d:需要恢復(fù)的數(shù)據(jù)庫實(shí)例,例如:test,當(dāng)然這個(gè)名稱也可以和備份時(shí)候的不一樣,比如test2
- -o:備份的數(shù)據(jù)存放位置,例如:c:\data\dump,當(dāng)然該目錄需要提前建立,在備份完成后,系統(tǒng)自動(dòng)在dump目錄下建立一個(gè)test目錄,這個(gè)目錄里面存放該數(shù)據(jù)庫實(shí)例的備份數(shù)據(jù)。
- --directoryperdb:備份數(shù)據(jù)所在位置,例如:c:\data\dump\test,這里為什么要多加一個(gè)test,而不是備份時(shí)候的dump,讀者自己查看提示吧!
- --drop:恢復(fù)的時(shí)候,先刪除當(dāng)前數(shù)據(jù),然后恢復(fù)備份的數(shù)據(jù)。就是說,恢復(fù)后,備份后添加修改的數(shù)據(jù)都會(huì)被刪除,慎用哦!
原始解釋:
-v [ --verbose ] be more verbose (include multiple times
for more verbosity e.g. -vvvvv)
--version print the program's version and exit
-h [ --host ] arg mongo host to connect to ( <set
name>/s1,s2 for sets)
--port arg server port. Can also use --host
hostname:port
--ipv6 enable IPv6 support (disabled by
default)
-u [ --username ] arg username
-p [ --password ] arg password
--authenticationDatabase arg user source (defaults to dbname)
--authenticationMechanism arg (=MONGODB-CR)
authentication mechanism
--dbpath arg directly access mongod database files
in the given path, instead of
connecting to a mongod server - needs
to lock the data directory, so cannot
be used if a mongod is currently
accessing the same path
--directoryperdb each db is in a separate directly
(relevant only if dbpath specified)
--journal enable journaling (relevant only if
dbpath specified)
-d [ --db ] arg database to use
-c [ --collection ] arg collection to use (some commands)
--objcheck validate object before inserting
(default)
--noobjcheck don't validate object before inserting
--filter arg filter to apply before inserting
--drop drop each collection before import
--oplogReplay replay oplog for point-in-time restore
--oplogLimit arg include oplog entries before the
provided Timestamp (seconds[:ordinal])
during the oplog replay; the ordinal
value is optional
--keepIndexVersion don't upgrade indexes to newest version
--noOptionsRestore don't restore collection options
--noIndexRestore don't restore indexes
--w arg (=0) minimum number of replicas per write
linux下面mongodb數(shù)據(jù)庫備份和恢復(fù)
linux下面我們可以創(chuàng)建一個(gè)自動(dòng)備份腳本,可以設(shè)置定時(shí)任務(wù),也可以手動(dòng)備份。我是手動(dòng)備份的。
首先創(chuàng)建一個(gè)sh命令,我是放在home下面的。
vim /home/mongoBeiFen.sh
輸入如下內(nèi)容:
#!/bin/bash shijie=`date +%Y%m%d%H` backmongodbFile=mongodb$shijie.tar.gz cd /home/mongoDbback/ /usr/local/mongo/bin/mongodump -h 127.0.0.1 --port 27017 -u mongo -p 123456 -d my_mongodb -o my_mongodb_dump/ tar czf $backmongodbFile my_mongodb_dump/ rm my_mongodb_dump -rf
解釋:
存放備份的文件夾是/home/mongoDbback/
-u是數(shù)據(jù)庫名用戶名 -p是密碼 -d是數(shù)據(jù)庫名 具體和window差不多,大家可以看下上面windows的解釋。
備份的時(shí)候只要運(yùn)行一下
./mongoBeiFen.sh
就可以了。
數(shù)據(jù)庫恢復(fù):
/usr/local/mongo/bin/mongorestore -d my_mongodb my_mongodb_dump/my_mongodb/*
指向每個(gè)文件
/usr/local/mongo/bin/mongorestore -h 127.0.0.1 --port 27017 -- drop --directoryperdb my_mongodb_dump/my_mongodb
指向一個(gè)目錄
有問題的話可以嘗試window的寫法:
/usr/local/mongo/bin/mongorestore -h 127.0.0.1:27017 -d test --drop --directoryperdb my_mongodb_dump/my_mongodb
- MongoDB的備份與恢復(fù)
- mongoDB4.2.8備份恢復(fù)與導(dǎo)出導(dǎo)入(推薦)
- 分布式文檔存儲(chǔ)數(shù)據(jù)庫之MongoDB備份與恢復(fù)的實(shí)踐詳解
- 使用centos系統(tǒng)中的crontab命令對(duì)mongodb定時(shí)備份恢復(fù)
- Mongodb實(shí)現(xiàn)定時(shí)備份與恢復(fù)的方法教程
- MongoDB 導(dǎo)出導(dǎo)入備份恢復(fù)數(shù)據(jù)詳解及實(shí)例
- MongoDB使用自帶的命令行工具進(jìn)行備份和恢復(fù)的教程
- Mongodb數(shù)據(jù)庫的備份與恢復(fù)操作實(shí)例
- MongoDB整庫備份與還原以及單個(gè)collection備份、恢復(fù)方法
- MongoDB的備份(mongodump)與恢復(fù)(mongorestore)
相關(guān)文章
MongoDB中javascript腳本編程簡(jiǎn)介和入門實(shí)例
作為一個(gè)數(shù)據(jù)庫,MongoDB有一個(gè)很大的優(yōu)勢(shì)——它使用js管理數(shù)據(jù)庫,所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活2014-04-04
MongoDB學(xué)習(xí)以及集群搭建的實(shí)踐全紀(jì)錄
這篇文章主要給大家介紹了關(guān)于MongoDB學(xué)習(xí)以及集群搭建的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09
MongoDB多表關(guān)聯(lián)查詢操作實(shí)例詳解
這篇文章主要介紹了MongoDB多表關(guān)聯(lián)查詢操作,結(jié)合實(shí)例形式詳細(xì)分析了MongoDB數(shù)據(jù)庫實(shí)現(xiàn)多表關(guān)聯(lián)查詢的相關(guān)原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-07-07
Mongodb 數(shù)據(jù)類型及Mongoose常用CURD
MongoDB 是一個(gè)開源的 NoSQL 數(shù)據(jù)庫,相比 MySQL 那樣的關(guān)系型數(shù)據(jù)庫,它更為輕巧、靈活,非常適合在數(shù)據(jù)規(guī)模很大、事務(wù)性不強(qiáng)的場(chǎng)合下使用,本文給大家介紹Mongodb 數(shù)據(jù)類型及Mongoose常用CURD,感興趣的朋友一起學(xué)習(xí)吧2016-01-01
Win10 64位安裝MongoDB數(shù)據(jù)庫的詳細(xì)教程
這篇文章主要介紹了Win10 64位安裝MongoDB數(shù)據(jù)庫的詳細(xì)教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12
mongodb數(shù)據(jù)庫實(shí)驗(yàn)之增刪查改
這篇文章主要介紹了mongodb數(shù)據(jù)庫實(shí)驗(yàn)之增刪查改的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11

