溫馨提示×

溫馨提示×

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

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

實(shí)戰(zhàn)MongoDB-Replication之Replica Set

發(fā)布時(shí)間:2020-06-02 07:55:15 來源:網(wǎng)絡(luò) 閱讀:40239 作者:virusswb 欄目:MongoDB數(shù)據(jù)庫

實(shí)戰(zhàn)MongoDB

Master-Slave

 

MongoDB支持不同服務(wù)之間的異步的數(shù)據(jù)復(fù)制,來實(shí)現(xiàn)failover(故障轉(zhuǎn)移,故障切換,故障恢復(fù)) and redundancy(數(shù)據(jù)冗余)。

同一時(shí)間,只有一個(gè)服務(wù)節(jié)點(diǎn)(primary或者master)支持寫入。

MongoDB支持兩種復(fù)制的模式:

  1. Master/Slave,主從復(fù)制,角色包括master和slave。
  2. Replica Set,復(fù)制集復(fù)制,角色包括primary和secondary。

 

介紹Master/Slave的官方地址:

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

介紹Replica Set的官方地址:

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

 

今天實(shí)戰(zhàn)的是replica set,也就是復(fù)制集復(fù)制。

  • replica set可以實(shí)現(xiàn)自動的failover和自動的recovery。
  • replica set由兩個(gè)或者更多的節(jié)點(diǎn)組成,實(shí)現(xiàn)彼此的復(fù)制。
  • replica set自動選擇primary節(jié)點(diǎn),沒有一個(gè)節(jié)點(diǎn)是固定的primary。
  • mongos會自動發(fā)現(xiàn)一個(gè)replica set的primary節(jié)點(diǎn)發(fā)生變化,并將寫操作發(fā)送給這個(gè)新的primary節(jié)點(diǎn)。

通常用于下面幾個(gè)場景

  • 數(shù)據(jù)冗余。
  • 自動failover,提供高可用性的服務(wù)。
  • 分散讀的負(fù)載。
  • 簡化維護(hù)(相對于master-slave來說)。
  • 災(zāi)難恢復(fù)。

首先還是啟動mongod,用于replica set的參數(shù)有兩個(gè):

--replSet <setname>,復(fù)制集的名稱。

--oplogSize <MB>,操作日志的大小,單位為MB。

這回我們在ubuntu下面配置replica set,先啟動兩個(gè)mongod節(jié)點(diǎn)。

 

  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 

你會注意到,上面兩個(gè)mongod的啟動參數(shù)replSet指定了相同的值shard1,也就是兩個(gè)個(gè)mongod節(jié)點(diǎn)處于同一個(gè)replica set中。

Replica Set的初始化

光啟動了兩個(gè)個(gè)mongod節(jié)點(diǎn),還不能提供任何的服務(wù),這時(shí)候你使用mongo連接之后,進(jìn)行db.book.insert會提示你no master,也就是說沒有primary節(jié)點(diǎn),所以他不知道往哪一個(gè)節(jié)點(diǎn)寫入數(shù)據(jù)。

在啟動了兩個(gè)個(gè)mongod節(jié)點(diǎn)之后,需要進(jìn)行初始化。

首先用mongo連接到任意一個(gè)mongod節(jié)點(diǎn),然后執(zhí)行下面的命令。

  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) 

出現(xiàn)下面的提示信息就代表成功了,如果沒有成功,可以google一下錯誤提示,會找到很多的答案的。

 

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

繼續(xù)執(zhí)行

 

  1. rs.status() 

可以查看replica set的狀態(tài),包括名稱,時(shí)間,當(dāng)前登錄的mongod是primary還是secondary,以及成員的信息等。

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

  • myState的值,如果是1代表當(dāng)前登錄的是primary;如果是2代表當(dāng)前登錄的是secondary。

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

成員信息中比較重要的是

  • state:1表示該host是當(dāng)前可以進(jìn)行讀寫,2:不能讀寫
  • health:1表示該host目前是正常的,0:異常

這時(shí)候登錄primary的mongod,插入一條數(shù)據(jù)。

 

  1. //假設(shè)10001是primary,可以通過查詢r(jià)s.status來獲取 
  2. mongo 192.168.0.21:10001 
  3.  
  4. use test 
  5. db.book.insert({'title':'computer'}) 

然后查看secondary的log文件,會發(fā)現(xiàn)發(fā)生了復(fù)制行為。

這時(shí)候登錄secondary,use test,db.book.find(),可以報(bào)錯了。

 

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

沒有關(guān)系,在secondary讀取數(shù)據(jù)還需要我們做最后的一步,在需要讀取數(shù)據(jù)的secondary上執(zhí)行。

 

  1. rs.slaveOK()

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

 

添加節(jié)點(diǎn)

 

啟動新mongod節(jié)點(diǎn)

 

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

連接primary節(jié)點(diǎn),執(zhí)行下面的命令。

 

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

 

強(qiáng)制一個(gè)節(jié)點(diǎn)成為primary

在mongodb2.0之后可以使用下面

相比master-slave,replica set的優(yōu)點(diǎn)就是沒有單點(diǎn)故障,primary故障之后,整個(gè)replica set會自動選擇一個(gè)健康的節(jié)點(diǎn)成為primary,承擔(dān)寫的任務(wù),可用性比master-slave的高,提供更高的可用性。

 

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI