什么是復(fù)制集?
保證數(shù)據(jù)在生產(chǎn)部署時(shí)的冗余和可靠性,通過(guò)在不同的機(jī)器上保存副本來(lái)保證數(shù)據(jù)的不會(huì)因?yàn)閱吸c(diǎn)損壞而丟失。能夠隨時(shí)應(yīng)對(duì)數(shù)據(jù)丟失、機(jī)器損壞帶來(lái)的風(fēng)險(xiǎn)。換一句話來(lái)說(shuō),還能提高讀取能力,用戶(hù)的讀取服務(wù)器和寫(xiě)入服務(wù)器在不同的地方,而且,由不同的服務(wù)器為不同的用戶(hù)提供服務(wù),提高整個(gè)系統(tǒng)的負(fù)載。
在MongoDB中就是復(fù)制集(replica set): 一組復(fù)制集就是一組mongod實(shí)例掌管同一個(gè)數(shù)據(jù)集,實(shí)例可以在不同的機(jī)器上面。實(shí)例中包含一個(gè)主導(dǎo),接受客戶(hù)端所有的寫(xiě)入操作,其他都是副本實(shí)例,從主服務(wù)器上獲得數(shù)據(jù)并保持同步。
基本的成員?
主節(jié)點(diǎn)(Primary) 包含了所有的寫(xiě)操作的日志。但是副本服務(wù)器集群包含有所有的主服務(wù)器數(shù)據(jù),因此當(dāng)主服務(wù)器掛掉了,就會(huì)在副本服務(wù)器上重新選取一個(gè)成為主服務(wù)器。MongoDB還細(xì)化將從節(jié)點(diǎn)(Primary)進(jìn)行了細(xì)化
Priority0 Priority0節(jié)點(diǎn)的選舉優(yōu)先級(jí)為0,不會(huì)被選舉為Primary
Hidden 隱藏節(jié)點(diǎn)將不會(huì)收到來(lái)自應(yīng)用程序的請(qǐng)求, 可使用Hidden節(jié)點(diǎn)做一些數(shù)據(jù)備份、離線計(jì)算的任務(wù),不會(huì)影響復(fù)制集的服務(wù)
Delayed Delayed節(jié)點(diǎn)必須是Hidden節(jié)點(diǎn),并且其數(shù)據(jù)落后與Primary一段時(shí)間(可配置,比如1個(gè)小時(shí));當(dāng)錯(cuò)誤或者無(wú)效的數(shù)據(jù)寫(xiě)入Primary時(shí),可通過(guò)Delayed節(jié)點(diǎn)的數(shù)據(jù)來(lái)恢復(fù)到之前的時(shí)間點(diǎn)。
從節(jié)點(diǎn)(Seconary) 正常情況下,復(fù)制集的Seconary會(huì)參與Primary選舉(自身也可能會(huì)被選為Primary),并從Primary同步最新寫(xiě)入的數(shù)據(jù),以保證與Primary存儲(chǔ)相同的數(shù)據(jù);增加Secondary節(jié)點(diǎn)可以提供復(fù)制集的讀服務(wù)能力,同時(shí)提升復(fù)制集的可用性。
仲裁節(jié)點(diǎn)(Arbiter) Arbiter節(jié)點(diǎn)只參與投票,不能被選為Primary,并且不從Primary同步數(shù)據(jù)。比如你部署了一個(gè)2個(gè)節(jié)點(diǎn)的復(fù)制集,1個(gè)Primary,1個(gè)Secondary,任意節(jié)點(diǎn)宕機(jī),復(fù)制集將不能提供服務(wù)了(無(wú)法選出Primary),這時(shí)可以給復(fù)制集添加一個(gè)Arbiter節(jié)點(diǎn),即使有節(jié)點(diǎn)宕機(jī),仍能選出Primary。