實戰MongoDB-Replication之Replica Set

實戰MongoDBweb

Master-Slavemongodb

 

MongoDB支持不一樣服務之間的異步的數據複製,來實現failover(故障轉移,故障切換,故障恢復) and redundancy(數據冗餘)。ubuntu

同一時間,只有一個服務節點(primary或者master)支持寫入。異步

MongoDB支持兩種複製的模式:ide

  1. Master/Slave,主從複製,角色包括master和slave。
  2. Replica Set,複製集複製,角色包括primary和secondary。

 

介紹Master/Slave的官方地址:google

http://www.mongodb.org/display/DOCS/Master+Slavespa

介紹Replica Set的官方地址:日誌

http://www.mongodb.org/display/DOCS/Replica+Setscode

 

今天實戰的是replica set,也就是複製集複製。orm

  • replica set能夠實現自動的failover和自動的recovery。
  • replica set由兩個或者更多的節點組成,實現彼此的複製。
  • replica set自動選擇primary節點,沒有一個節點是固定的primary。
  • mongos會自動發現一個replica set的primary節點發生變化,並將寫操做發送給這個新的primary節點。

一般用於下面幾個場景

  • 數據冗餘。
  • 自動failover,提供高可用性的服務。
  • 分散讀的負載。
  • 簡化維護(相對於master-slave來講)。
  • 災難恢復。

首先仍是啓動mongod,用於replica set的參數有兩個:

--replSet <setname>,複製集的名稱。

--oplogSize <MB>,操做日誌的大小,單位爲MB。

這回咱們在ubuntu下面配置replica set,先啓動兩個mongod節點。

 

  
  
           
  
  
  1. mongod --dbpath /home/andyshi/mongo1/ --logpath /home/andyshi/mongo1/log.log --replSet shard1 --port 10001 --bind_ip 192.168.0.21 

 

  
  
           
  
  
  1. mongod --dbpath /home/andyshi/mongo2/ --logpath /home/andyshi/mongo2/log.log --replSet shard1 --port 10002 --bind_ip 192.168.0.21 

你會注意到,上面兩個mongod的啓動參數replSet指定了相同的值shard1,也就是兩個個mongod節點處於同一個replica set中。

Replica Set的初始化

光啓動了兩個個mongod節點,還不能提供任何的服務,這時候你使用mongo鏈接以後,進行db.book.insert會提示你no master,也就是說沒有primary節點,因此他不知道往哪個節點寫入數據。

在啓動了兩個個mongod節點以後,須要進行初始化。

首先用mongo鏈接到任意一個mongod節點,而後執行下面的命令。

  
  
           
  
  
  1. cfg={_id:'shard1',members:[ 
  2. {_id:0,host:'192.168.0.21:10001'}, 
  3. {_id:1,host:'192.168.0.21:10002'}] 
  4. rs.initiate(cfg) 

出現下面的提示信息就表明成功了,若是沒有成功,能夠google一下錯誤提示,會找到不少的答案的。

 

  
  
           
  
  
  1.    "info" : "Config now saved locally.  Should come online in about a minute.", 
  2.    "ok" : 1 

繼續執行

 

  
  
           
  
  
  1. rs.status() 

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

在replica set的信息中,其中重要的是:

  • myState的值,若是是1表明當前登陸的是primary;若是是2表明當前登陸的是secondary。

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

成員信息中比較重要的是

  • state:1表示該host是當前能夠進行讀寫,2:不能讀寫
  • health:1表示該host目前是正常的,0:異常

這時候登陸primary的mongod,插入一條數據。

 

  
  
           
  
  
  1. //假設10001是primary,能夠經過查詢rs.status來獲取 
  2. mongo 192.168.0.21:10001 
  3.  
  4. use test 
  5. db.book.insert({'title':'computer'}) 

而後查看secondary的log文件,會發現發生了複製行爲。

這時候登陸secondary,use test,db.book.find(),能夠報錯了。

 

  
  
           
  
  
  1. error: { "$err" : "not master and slaveok=false", "code" : 13435 } 

沒有關係,在secondary讀取數據還須要咱們作最後的一步,在須要讀取數據的secondary上執行。

 

  
  
           
  
  
  1. rs.slaveOK()

這時候再次db.book.find(),正常顯示結果了,沒有問題了。

 

添加節點

 

啓動新mongod節點

 

  
  
           
  
  
  1. mongod --dbpath /home/andyshi/mongo3/ --logpath /home/andyshi/mongo3/log.log --replSet shard1 --port 10003 --bind_ip 192.168.0.21   

鏈接primary節點,執行下面的命令。

 

  
  
           
  
  
  1. rs.add('192.168.0.21:10003') 
  2. rs.addArb('192.168.0.21:10003') 
  3. //從新配置 
  4. rs.reconfig(rs.conf()) 

 

強制一個節點成爲primary

在mongodb2.0以後可使用下面

相比master-slave,replica set的優勢就是沒有單點故障,primary故障以後,整個replica set會自動選擇一個健康的節點成爲primary,承擔寫的任務,可用性比master-slave的高,提供更高的可用性。

相關文章
相關標籤/搜索