91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MongoDB中副本集的示例分析

發布時間:2021-08-07 10:25:19 來源:億速云 閱讀:140 作者:小新 欄目:MongoDB數據庫

這篇文章主要介紹了MongoDB中副本集的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

具體如下:

replication set復制集,
復制集,多臺服務器維護相同的數據副本,提高服務器的可用性。
MongoDB復制是將數據同步在多個服務器的過程。
復制提供了數據的冗余備份,并在多個服務器上存儲數據副本,提高了數據的可用性, 并可以保證數據的安全性。
復制還允許您從硬件故障和服務中斷中恢復數據。

設置過程:

(1)創建示例

假設創建三臺,創建三個實例目錄和日志目錄:
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

說明:

參數--replSet設置一樣,才能屬于同一個復制集
參數--smallfiles可以節省空間,提高速度。

然后使用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'}
]
}

執行后,使用 printjson(rsconf)查看剛才的配置。

然后執行初始化:

>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>

查看節點:

rs.status()

刪除節點:

rs.remove('127.0.0.1:27019')

添加節點:

rs.add('127.0.0.1:27019')

切換節點:

默認是在27017端口,即rs2:PRIMARY>狀態,
退出mongo客戶端命令模式,
切換到另一個端口:

[test@localhost bin]$ ./mongo --port=27018,

即切換到rs2:SECONDARY>狀態。

測試:

在主服務上,創建庫和集合,

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" }

去從服務上查看

show dbs

然后看到有錯誤,具體錯誤信息是:

...
"errmsg" : "not master and slaveOk=false",
...

是因為slave默認不允許讀寫:

>rs.slaveOk();

然后就可以看到主服務器創建的庫和集合了。

同理27019也需要執行這個命令才能自動同步和讀寫。

當主服務器27017停掉的時候,
第二個27018就自動變成主服務器master狀態。
但是27019需要再次執行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中副本集的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

铜鼓县| 驻马店市| 贵德县| 阜阳市| 阜宁县| 高安市| 循化| 江源县| 白朗县| 蒙城县| 西乡县| 鸡东县| 西华县| 道孚县| 客服| 新巴尔虎左旗| 日照市| 平原县| 东辽县| 桦南县| 壶关县| 霍城县| 罗定市| 汝州市| 全南县| 务川| 鹿邑县| 广德县| 江城| 惠州市| 威宁| 敦化市| 道真| 七台河市| 遵义市| 门头沟区| 贵阳市| 拜泉县| 舞阳县| 册亨县| 凉山|