MongoDB 復(fù)制(副本集)學(xué)習(xí)筆記
本文實例講述了MongoDB 復(fù)制(副本集)。分享給大家供大家參考,具體如下:
replication set復(fù)制集,
復(fù)制集,多臺服務(wù)器維護相同的數(shù)據(jù)副本,提高服務(wù)器的可用性。
MongoDB復(fù)制是將數(shù)據(jù)同步在多個服務(wù)器的過程。
復(fù)制提供了數(shù)據(jù)的冗余備份,并在多個服務(wù)器上存儲數(shù)據(jù)副本,提高了數(shù)據(jù)的可用性, 并可以保證數(shù)據(jù)的安全性。
復(fù)制還允許您從硬件故障和服務(wù)中斷中恢復(fù)數(shù)據(jù)。
設(shè)置過程:
(1)創(chuàng)建示例
假設(shè)創(chuàng)建三臺,創(chuàng)建三個實例目錄和日志目錄:
mkdir /home/m17 /home/m18 /home/m19 /home/mlog
啟動三個示例,端口分別為27017、27018、27019。
./mongod --dbpath=/home/m17 --logpath=/home/mlog/m17.log --fork --port=27017 --replSet=rs2 --smallfiles ./mongod --dbpath=/home/m18 --logpath=/home/mlog/m18.log --fork --port=27018 --replSet=rs2 --smallfiles ./mongod --dbpath=/home/m19 --logpath=/home/mlog/m19.log --fork --port=27019 --replSet=rs2 --smallfiles
說明:
參數(shù)--replSet設(shè)置一樣,才能屬于同一個復(fù)制集
參數(shù)--smallfiles可以節(jié)省空間,提高速度。
然后使用ps aux | grep mongo可以查看到啟動起來的三個端口。
(2)配置
使用客戶端連接mongo進行配置:
[test@localhost bin]$ ./mongo
要管理配置,所以切換到admin上:
>use admin
(配置是json格式)
var rsconf = {
_id:'rs2',
members:[
{"_id":0,host:'192.168.8.172:27017'},
{_id:1,host:'192.168.8.172:27018'},
{_id:2,host:'192.168.8.172:27019'}
]
}
如果沒有配置ip,使用127.0.0.1
var rsconf = {
_id:'rs2',
members:[
{_id:0,host:'127.0.0.1:27017'},
{_id:1,host:'127.0.0.1:27018'},
{_id:2,host:'127.0.0.1:27019'}
]
}
執(zhí)行后,使用 printjson(rsconf)查看剛才的配置。
然后執(zhí)行初始化:
>rs.initiate(rsconf);
> rs.initiate(rsconf);
{
"ok" : 1,
"operationTime" : Timestamp(1539933041, 1),
"$clusterTime" : {
"clusterTime" : Timestamp(1539933041, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
}
rs2:SECONDARY>
查看節(jié)點:
rs.status()
刪除節(jié)點:
rs.remove('127.0.0.1:27019')
添加節(jié)點:
rs.add('127.0.0.1:27019')
切換節(jié)點:
默認是在27017端口,即rs2:PRIMARY>狀態(tài),
退出mongo客戶端命令模式,
切換到另一個端口:
[test@localhost bin]$ ./mongo --port=27018,
即切換到rs2:SECONDARY>狀態(tài)。
測試:
在主服務(wù)上,創(chuàng)建庫和集合,
rs2:PRIMARY> use student
switched to db student
rs2:PRIMARY> db.user.insert({uid:1,name:'zhang san'})
WriteResult({ "nInserted" : 1 })
rs2:PRIMARY> db.user.find();
{ "_id" : ObjectId("5bc9889f85a0986431fd2499"), "uid" : 1, "name" : "zhang san" }
去從服務(wù)上查看
show dbs
然后看到有錯誤,具體錯誤信息是:
...
"errmsg" : "not master and slaveOk=false",
...
是因為slave默認不允許讀寫:
>rs.slaveOk();
然后就可以看到主服務(wù)器創(chuàng)建的庫和集合了。
同理27019也需要執(zhí)行這個命令才能自動同步和讀寫。
當主服務(wù)器27017停掉的時候,
第二個27018就自動變成主服務(wù)器master狀態(tài)。
但是27019需要再次執(zhí)行rs.slaveOk()才能自動同步讀寫。
shell腳本:
#!/bin/bash
IP=127.0.0.1
NA=rs2
sudo mkdir -p /home/m17 /home/m18 /home/m19 /home/mlog
sudo chmod -R 777 /home/m17 /home/m18 /home/m19 /home/mlog
./mongod --dbpath=/home/m17 --logpath=/home/mlog/m17.log --fork --port=27017 --replSet=${NA} --smallfiles
./mongod --dbpath=/home/m18 --logpath=/home/mlog/m18.log --fork --port=27018 --replSet=${NA} --smallfiles
./mongod --dbpath=/home/m19 --logpath=/home/mlog/m19.log --fork --port=27019 --replSet=${NA} --smallfiles
./mongo <<EOF
use admin
var rsconf = {
_id:'rs2',
members:[
{_id:0,host:'${IP}:27017'},
{_id:1,host:'${IP}:27018'},
{_id:2,host:'${IP}:27019'}
]
}
rs.initiate(rsconf)
希望本文所述對大家MongoDB數(shù)據(jù)庫程序設(shè)計有所幫助。
相關(guān)文章
Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作
這篇文章主要介紹了Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的問題及操作方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
SpringBoot?集成MongoDB實現(xiàn)文件上傳功能
這篇文章主要介紹了SpringBoot?集成MongoDB實現(xiàn)文件上傳,主要通過示例代碼記錄文件上傳的步驟,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04
centos7防火墻導(dǎo)致java程序訪問mongodb3.0.1時報錯的問題分析
這篇文章主要介紹了centos7防火墻導(dǎo)致java程序訪問mongodb3.0.1時報錯的問題分析,需要的朋友參考下2017-01-01
CentOS 6.5系統(tǒng)中使用yum安裝MongoDB 2.6 教程
這篇文章主要介紹了CentOS 6.5系統(tǒng)中使用yum安裝MongoDB 2.6 教程,本文共分5個步驟完成MongoDB的安裝,需要的朋友可以參考下2015-01-01
Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠程連接
這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下安裝MongoDB并內(nèi)網(wǎng)穿透遠程連接的相關(guān)資料,文中通過圖文將步驟介紹的非常詳細,對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-03-03

