mongodb添加arbiter節(jié)點(diǎn)的方法示例
前言
在創(chuàng)建mongodb的replica set的時候,只是做成了1主2從,沒有做成1主1從1仲裁。這我們將一個幾點(diǎn)從replica set中刪除,再以仲裁節(jié)點(diǎn)的身份加入到replica set中:
1.初始狀態(tài):
shard1ReplSet:PRIMARY> rs.status();rs.status(); { "set" : "shard1ReplSet", "date" : ISODate("2017-02-21T07:48:03.058Z"), "myState" : 1, "term" : NumberLong(1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(0, 0), "t" : NumberLong(-1) }, "appliedOpTime" : { "ts" : Timestamp(1487663274, 1), "t" : NumberLong(1) }, "durableOpTime" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) } }, "members" : [ { "_id" : 0, "name" : "10.13.0.130:22001", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 76672, "optime" : { "ts" : Timestamp(1487663274, 1), "t" : NumberLong(1) }, "optimeDate" : ISODate("2017-02-21T07:47:54Z"), "electionTime" : Timestamp(1487587993, 1), "electionDate" : ISODate("2017-02-20T10:53:13Z"), "configVersion" : 1, "self" : true }, { "_id" : 1, "name" : "10.13.0.131:22001", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 75300, "optime" : { "ts" : Timestamp(1487663274, 1), "t" : NumberLong(1) }, "optimeDurable" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) }, "optimeDate" : ISODate("2017-02-21T07:47:54Z"), "optimeDurableDate" : ISODate("2017-02-20T10:53:02Z"), "lastHeartbeat" : ISODate("2017-02-21T07:48:02.150Z"), "lastHeartbeatRecv" : ISODate("2017-02-21T07:48:02.215Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.13.0.132:22001", "configVersion" : 1 }, { "_id" : 2, "name" : "10.13.0.132:22001", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 75300, "optime" : { "ts" : Timestamp(1487663274, 1), "t" : NumberLong(1) }, "optimeDurable" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) }, "optimeDate" : ISODate("2017-02-21T07:47:54Z"), "optimeDurableDate" : ISODate("2017-02-20T10:53:02Z"), "lastHeartbeat" : ISODate("2017-02-21T07:48:02.889Z"), "lastHeartbeatRecv" : ISODate("2017-02-21T07:48:01.503Z"), "pingMs" : NumberLong(0), "syncingTo" : "10.13.0.130:22001", "configVersion" : 1 } ], "ok" : 1 } shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY>
2.刪除節(jié)點(diǎn):
shard1ReplSet:PRIMARY> rs.remove("10.13.0.132:22001"); rs.remove("10.13.0.132:22001"); { "ok" : 1 } shard1ReplSet:PRIMARY> rs.status();rs.status(); { "set" : "shard1ReplSet", "date" : ISODate("2017-02-21T07:50:52.934Z"), "myState" : 1, "term" : NumberLong(1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(0, 0), "t" : NumberLong(-1) }, "appliedOpTime" : { "ts" : Timestamp(1487663447, 1), "t" : NumberLong(1) }, "durableOpTime" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) } }, "members" : [ { "_id" : 0, "name" : "10.13.0.130:22001", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 76841, "optime" : { "ts" : Timestamp(1487663447, 1), "t" : NumberLong(1) }, "optimeDate" : ISODate("2017-02-21T07:50:47Z"), "electionTime" : Timestamp(1487587993, 1), "electionDate" : ISODate("2017-02-20T10:53:13Z"), "configVersion" : 2, "self" : true }, { "_id" : 1, "name" : "10.13.0.131:22001", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 75470, "optime" : { "ts" : Timestamp(1487663447, 1), "t" : NumberLong(1) }, "optimeDurable" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) }, "optimeDate" : ISODate("2017-02-21T07:50:47Z"), "optimeDurableDate" : ISODate("2017-02-20T10:53:02Z"), "lastHeartbeat" : ISODate("2017-02-21T07:50:51.182Z"), "lastHeartbeatRecv" : ISODate("2017-02-21T07:50:52.212Z"), "pingMs" : NumberLong(0), "configVersion" : 2 } ], "ok" : 1 } shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY>
3.添加成arbiter節(jié)點(diǎn):
shard1ReplSet:PRIMARY> rs.addArb("10.13.0.132:22001");rs.addArb("10.13.0.132:22001"); { "ok" : 1 } shard1ReplSet:PRIMARY> shard1ReplSet:PRIMARY> rs.status();rs.status(); { "set" : "shard1ReplSet", "date" : ISODate("2017-02-21T07:54:05.161Z"), "myState" : 1, "term" : NumberLong(1), "heartbeatIntervalMillis" : NumberLong(2000), "optimes" : { "lastCommittedOpTime" : { "ts" : Timestamp(0, 0), "t" : NumberLong(-1) }, "appliedOpTime" : { "ts" : Timestamp(1487663637, 1), "t" : NumberLong(1) }, "durableOpTime" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) } }, "members" : [ { "_id" : 0, "name" : "10.13.0.130:22001", "health" : 1, "state" : 1, "stateStr" : "PRIMARY", "uptime" : 77034, "optime" : { "ts" : Timestamp(1487663637, 1), "t" : NumberLong(1) }, "optimeDate" : ISODate("2017-02-21T07:53:57Z"), "electionTime" : Timestamp(1487587993, 1), "electionDate" : ISODate("2017-02-20T10:53:13Z"), "configVersion" : 3, "self" : true }, { "_id" : 1, "name" : "10.13.0.131:22001", "health" : 1, "state" : 2, "stateStr" : "SECONDARY", "uptime" : 75662, "optime" : { "ts" : Timestamp(1487663637, 1), "t" : NumberLong(1) }, "optimeDurable" : { "ts" : Timestamp(1487587982, 1), "t" : NumberLong(-1) }, "optimeDate" : ISODate("2017-02-21T07:53:57Z"), "optimeDurableDate" : ISODate("2017-02-20T10:53:02Z"), "lastHeartbeat" : ISODate("2017-02-21T07:54:03.210Z"), "lastHeartbeatRecv" : ISODate("2017-02-21T07:54:02.211Z"), "pingMs" : NumberLong(0), "configVersion" : 3 }, { "_id" : 2, "name" : "10.13.0.132:22001", "health" : 1, "state" : 7, "stateStr" : "ARBITER", "uptime" : 5, "lastHeartbeat" : ISODate("2017-02-21T07:54:03.214Z"), "lastHeartbeatRecv" : ISODate("2017-02-21T07:54:02.274Z"), "pingMs" : NumberLong(0), "configVersion" : 3 } ], "ok" : 1 } shard1ReplSet:PRIMARY>
注1: mongodb 3.4之后,雖然要求config server為replica set,但是不支持arbiter。
添加的時候,會報(bào)錯:
cfgReplSet:PRIMARY> rs.addArb("10.13.0.132:21000");rs.addArb("10.13.0.132:21000"); { "ok" : 0, "errmsg" : "Arbiters are not allowed in replica set configurations being used for config servers", "code" : 103, "codeName" : "NewReplicaSetConfigurationIncompatible" } cfgReplSet:PRIMARY>
注2:rs.reconfig()也可以進(jìn)行操作,效果類似re.remove+rs.addArb,詳見:mongodb官方文檔- Remove Members from Replica Set
總結(jié)
以上就是關(guān)于mongodb添加arbiter節(jié)點(diǎn)的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
- 關(guān)于mongoose連接mongodb重復(fù)訪問報(bào)錯的解決辦法
- NodeJS連接MongoDB數(shù)據(jù)庫時報(bào)錯的快速解決方法
- perl操作MongoDB報(bào)錯undefined symbol: HeUTF8解決方法
- centos7防火墻導(dǎo)致java程序訪問mongodb3.0.1時報(bào)錯的問題分析
- mongodb replica set 添加刪除節(jié)點(diǎn)的2種方法
- Mongodb增加、移除Arbiter節(jié)點(diǎn)實(shí)例
- MongoDB添加secondary節(jié)點(diǎn)的2種方法詳解
- MongoDB添加仲裁節(jié)點(diǎn)報(bào)錯:replica set IDs do not match的解決方法
相關(guān)文章
毫不費(fèi)力!在Ubuntu上安裝MongoDB7.0的簡易指南!
MongoDB是一種流行的NoSQL數(shù)據(jù)庫管理系統(tǒng),用于處理大量結(jié)構(gòu)化和半結(jié)構(gòu)化數(shù)據(jù),本文提供了在Ubuntu上安裝MongoDB?7.0的詳細(xì)步驟,以下步驟包含了在Ubuntu系統(tǒng)中安裝MongoDB的必要軟件包、配置MongoDB數(shù)據(jù)目錄、配置MongoDB數(shù)據(jù)庫的認(rèn)證方式等信息,需要的朋友可以參考下2023-10-10MongoDB數(shù)據(jù)庫查詢性能提高40倍的經(jīng)歷分享
大家在使用 MongoDB 的時候有沒有碰到過性能問題呢?下面這篇文章主要給大家分享了MongoDB數(shù)據(jù)庫查詢性能提高40倍的經(jīng)歷,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02MongoDB中javascript腳本編程簡介和入門實(shí)例
作為一個數(shù)據(jù)庫,MongoDB有一個很大的優(yōu)勢——它使用js管理數(shù)據(jù)庫,所以也能夠使用js腳本進(jìn)行復(fù)雜的管理——這種方法非常靈活2014-04-04Windows系統(tǒng)啟動MongoDB報(bào)錯無法連接服務(wù)器的問題及解決方案
在Windows系統(tǒng)中啟動MongoDB時遇到連接拒絕的錯誤,通常是因?yàn)榉?wù)未運(yùn)行或配置問題,本文給大家分享Windows系統(tǒng)啟動MongoDB報(bào)錯無法連接服務(wù)器的問題及解決方案,一起看看吧2024-10-10