mongodb replica set 副本集 安裝部署(三)

1.節點類型

         簡單的說副本集(replica set)就是有自動故障恢復功能的主從集羣,主從集羣和副本集最爲明顯的區別就是副本集沒有固定的主節點,整個集羣會選舉出一個主節點。
         節點類型

         standard:常規節點,它存儲一份完整的數據副本,參與選舉投票,有可能成爲primary節點。

         passive:存儲了完整的數據副本,參與投票,不能成爲primary節點。

         arbiter:仲裁節點,只參與投票,不接收復制的數據,也不能成爲primary節點。
         一個repica sets節點數量最好爲奇數(odd)。

        實驗是三個節點:

        兩個standard節點(這兩個節點直接可以互切primary secondary)。

        一個arbiter節點,它手中握着一張選票,決定上面兩個standard節點中的哪一個可以成爲primay。

2.
relica sets 集羣三節點分佈
 
   實驗是三個節點:

   兩個standard節點(這兩個節點直接可以互切primary secondary)。
   node1ip:192.168.137.12
   node2ip:192.168.137.13

   一個arbiter節點,它手中握着一張選票,決定上面兩個standard節點中的哪一個可以成爲primay。
   node3ip:192.168.137.14

3.配置步驟

  啓動第一個standard節點
   /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.13:27017  --maxConns=200 --fork
 
  啓動第二個standard節點
   /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.12:27017  --maxConns=200 --fork

 啓動第三個arbiter節點
  /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.13:27017,192.168.137.12:27017  --maxConns=200 --fork


 以上配置完成後再任意一個standard節點運行mongo
  > use admin
  > cfg={_id:'test',members:[
  ...{_id:0,host:'192.168.137.12:27017'},
  ...{_id:1,host:'192.168.137.13:27017'}]
  ...}

   出現下面的提示信息就代表成功了
   "info" : "Config now saved locally.  Should come online in about a minute.",
   "ok" : 1

  然後再加入arbiter節點
  PRIMARY> rs.addArb("192.168.137.14:27017");

 到了這裏,這個集羣已經配置完成,三個節點的角色已經分配完畢,怎麼查看是否正常呢

  rs.status()通過這個命令,可以查看各個節點的ip、角色已經是否正常

可以查看replica set的狀態,包括名稱,時間,當前登錄的mongod是primary還是secondary,以及成員的信息等。

在replica set的信息中,其中重要的是:
myState的值,如果是1代表當前登錄的是primary;如果是2代表當前登錄的是secondary。

成員信息中包括地址,健康狀態,是primary還是secondary等。

成員信息中比較重要的是
state:1表示該host是當前可以進行讀寫,2:不能讀寫
health:1表示該host目前是正常的,0:異常


4.mongodb replica sets 的管理

添加普通數據節點
PRIMARY> rs.add("ip:port")

刪除節點
PRIMARY> rs.remove("ip:port")

顯示當前誰是primay
PRIMARY> rs.isMaster()

將一個普通數據節點修改爲passive節點,也就是能同步數據、投票,但是不能成爲primay。
除了仲裁節點,其他每個節點都有個優先權,我們可以通過設置優先權來決定誰的成爲primay的權重最大。
MongoDB replica sets中通過設置priority的值來決定優先權的大小,這個值的範圍是0--100,值越大,優先權越高。
如果值是0,那麼不能成爲primay。


通過rs.conf()命令查看出節點列表
將node2節點的priority值修改成0,讓它只接收數據,不參與成爲primary的競爭。在PRIMARY節點上操作:
cfg = rs.conf()
cfg.members[1].priority = 0
rs.reconfig(cfg)


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章