寫在前面
本文已經(jīng)假設(shè)你已經(jīng)安裝好了Mongodb(2.6),并且已經(jīng)開啟了auth。
用戶
首先我們添加備份和恢復(fù)數(shù)據(jù)所需的用戶,這個(gè)用戶需要有readWrite和userAdmin權(quán)限
$ mongo
$ use admin
$ db.auth("admin", "youradminpasswd");
$ use backupdb
$ db.addUser({ user: "backup", pwd: "passwd", roles: [ "readWrite", "userAdmin" ] })
備份
注:此命令是在控制臺中執(zhí)行
我們使用mongodump來進(jìn)行數(shù)據(jù)的備份(注意:mongodump不會備份local數(shù)據(jù)庫中內(nèi)容)。
mongodump可以通過以下兩種方式來進(jìn)行數(shù)據(jù)的備份:
連接到mongod或者mongos
直接訪問數(shù)據(jù)文件
這個(gè)工具可以備份整個(gè)服務(wù)器、單個(gè)database或者單個(gè)collection的數(shù)據(jù),也可以通過查詢語句只備份collection中的部分?jǐn)?shù)據(jù)。
如果不帶任何參數(shù)直接執(zhí)行mongodump,那么它會去連接本地(127.0.0.1或者localhost)27017端口上的MongoDB實(shí)例,并且會創(chuàng)建名為dump的備份。
$ mongodump --host mongodb.example.net --port 27017 --db test --collection some --username backup --password passwd
以上會使mongodump連接到mongodb.example.net:27017上的mongod,并且把dbtest中的somecollection備份到dump目錄下
注意:從Mongodb2.2版本開始,mongodump使用的數(shù)據(jù)格式與舊版本的mongod實(shí)例不兼容。所以不要使用新版本(>=2.2)的mongodump去備份舊數(shù)據(jù)。
恢復(fù)
使用mongodump備份的數(shù)據(jù),需要使用mongorestore來恢復(fù)。
mongorestore恢復(fù)數(shù)據(jù)的方式與mongodump相對應(yīng),也是分為兩種:
連接到mongod或者mongos
直接寫入到數(shù)據(jù)文件
mongorestore既可以恢復(fù)整個(gè)備份也可以恢復(fù)一部分。
$ mongorestore --host mongodb.example.net --port 27017 --db test --collection some --username backup --password password /data/backup
以上會從/data/backup中恢復(fù)數(shù)據(jù),其中只恢復(fù)testdb中somecollection到mongodb.example.net:27017中。如果不指定--host和--portoption,那么mongorestore會默認(rèn)使用localhost:27017。
注:在還原時(shí)必需在將要還原的數(shù)據(jù)庫上新建將要還原的數(shù)據(jù)與所屬的用戶 --drop的意思是刪除庫中原來的數(shù)據(jù)庫并將數(shù)據(jù)庫還原上去
此命令是在控制臺中執(zhí)行