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