成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

Redis主從復(fù)制以及主從復(fù)制原理

snowLu / 2483人閱讀

摘要:前者稱為主節(jié)點(diǎn),后者稱為從節(jié)點(diǎn)數(shù)據(jù)的復(fù)制是單向的,只能由主節(jié)點(diǎn)到從節(jié)點(diǎn)。主從復(fù)制的作用數(shù)據(jù)冗余主從復(fù)制實(shí)現(xiàn)了數(shù)據(jù)的熱備份,是持久化之外的一種數(shù)據(jù)冗余方式。檢測主節(jié)點(diǎn)當(dāng)前是否可接受處理命令。

Redis是一個(gè)開源的使用ANSI C語言編寫、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫,并提供多種語言的API。從2010年3月15日起,Redis的開發(fā)工作由VMware主持。從2013年5月開始,Redis的開發(fā)由Pivotal贊助。
概述

在現(xiàn)有企業(yè)中80%公司大部分使用的是redis單機(jī)服務(wù),在實(shí)際的場景當(dāng)中單一節(jié)點(diǎn)的redis容易面臨風(fēng)險(xiǎn)。

面臨問題

機(jī)器故障。我們部署到一臺 Redis 服務(wù)器,當(dāng)發(fā)生機(jī)器故障時(shí),需要遷移到另外一臺服務(wù)器并且要保證數(shù)據(jù)是同步的。而數(shù)據(jù)是最重要的,如果你不在乎,基本上也就不會使用 Redis 了。

容量瓶頸。當(dāng)我們有需求需要擴(kuò)容 Redis 內(nèi)存時(shí),從 16G 的內(nèi)存升到 64G,單機(jī)肯定是滿足不了。當(dāng)然,你可以重新買個(gè) 128G 的新機(jī)器。

解決辦法

要實(shí)現(xiàn)分布式數(shù)據(jù)庫的更大的存儲容量和承受高并發(fā)訪問量,我們會將原來集中式數(shù)據(jù)庫的數(shù)據(jù)分別存儲到其他多個(gè)網(wǎng)絡(luò)節(jié)點(diǎn)上。

Redis 為了解決這個(gè)單一節(jié)點(diǎn)的問題,也會把數(shù)據(jù)復(fù)制多個(gè)副本部署到其他節(jié)點(diǎn)上進(jìn)行復(fù)制,實(shí)現(xiàn) Redis的高可用,實(shí)現(xiàn)對數(shù)據(jù)的冗余備份,從而保證數(shù)據(jù)和服務(wù)的高可用。
主從復(fù)制 什么是主從復(fù)制

主從復(fù)制,是指將一臺Redis服務(wù)器的數(shù)據(jù),復(fù)制到其他的Redis服務(wù)器。前者稱為主節(jié)點(diǎn)(master),后者稱為從節(jié)點(diǎn)(slave),數(shù)據(jù)的復(fù)制是單向的,只能由主節(jié)點(diǎn)到從節(jié)點(diǎn)。

默認(rèn)情況下,每臺Redis服務(wù)器都是主節(jié)點(diǎn);且一個(gè)主節(jié)點(diǎn)可以有多個(gè)從節(jié)點(diǎn)(或沒有從節(jié)點(diǎn)),但一個(gè)從節(jié)點(diǎn)只能有一個(gè)主節(jié)點(diǎn)。

主從復(fù)制的作用

數(shù)據(jù)冗余:主從復(fù)制實(shí)現(xiàn)了數(shù)據(jù)的熱備份,是持久化之外的一種數(shù)據(jù)冗余方式。

故障恢復(fù):當(dāng)主節(jié)點(diǎn)出現(xiàn)問題時(shí),可以由從節(jié)點(diǎn)提供服務(wù),實(shí)現(xiàn)快速的故障恢復(fù);實(shí)際上是一種服務(wù)的冗余。

負(fù)載均衡:在主從復(fù)制的基礎(chǔ)上,配合讀寫分離,可以由主節(jié)點(diǎn)提供寫服務(wù),由從節(jié)點(diǎn)提供讀服務(wù)(即寫Redis數(shù)據(jù)時(shí)應(yīng)用連接主節(jié)點(diǎn),讀Redis數(shù)據(jù)時(shí)應(yīng)用連接從節(jié)點(diǎn)),分擔(dān)服務(wù)器負(fù)載;尤其是在寫少讀多的場景下,通過多個(gè)從節(jié)點(diǎn)分擔(dān)讀負(fù)載,可以大大提高Redis服務(wù)器的并發(fā)量。

讀寫分離:可以用于實(shí)現(xiàn)讀寫分離,主庫寫、從庫讀,讀寫分離不僅可以提高服務(wù)器的負(fù)載能力,同時(shí)可根據(jù)需求的變化,改變從庫的數(shù)量;

高可用基石:除了上述作用以外,主從復(fù)制還是哨兵和集群能夠?qū)嵤┑幕A(chǔ),因此說主從復(fù)制是Redis高可用的基礎(chǔ)。

主從復(fù)制啟用

從節(jié)點(diǎn)開啟主從復(fù)制,有3種方式:

配置文件: 在從服務(wù)器的配置文件中加入:slaveof

啟動命令: redis-server啟動命令后加入 --slaveof

客戶端命令: Redis服務(wù)器啟動后,直接通過客戶端執(zhí)行命令:slaveof
,則該Redis實(shí)例成為從節(jié)點(diǎn)。

通過 ?info replication 命令可以看到復(fù)制的一些信息
主從復(fù)制原理

主從復(fù)制過程大體可以分為3個(gè)階段:連接建立階段(即準(zhǔn)備階段)、數(shù)據(jù)同步階段、命令傳播階段。

在從節(jié)點(diǎn)執(zhí)行 slaveof 命令后,復(fù)制過程便開始運(yùn)作,下面圖示大概可以看到,
從圖中可以看出復(fù)制過程大致分為6個(gè)過程

主從配置之后的日志記錄也可以看出這個(gè)流程

1)保存主節(jié)點(diǎn)(master)信息。
執(zhí)行 slaveof 后 Redis 會打印如下日志:

2)從節(jié)點(diǎn)(slave)內(nèi)部通過每秒運(yùn)行的定時(shí)任務(wù)維護(hù)復(fù)制相關(guān)邏輯,當(dāng)定時(shí)任務(wù)發(fā)現(xiàn)存在新的主節(jié)點(diǎn)后,會嘗試與該節(jié)點(diǎn)建立網(wǎng)絡(luò)連接

從節(jié)點(diǎn)與主節(jié)點(diǎn)建立網(wǎng)絡(luò)連接

從節(jié)點(diǎn)會建立一個(gè) socket 套接字,從節(jié)點(diǎn)建立了一個(gè)端口為51234的套接字,專門用于接受主節(jié)點(diǎn)發(fā)送的復(fù)制命令。從節(jié)點(diǎn)連接成功后打印如下日志:

如果從節(jié)點(diǎn)無法建立連接,定時(shí)任務(wù)會無限重試直到連接成功或者執(zhí)行 slaveof no one 取消復(fù)制

關(guān)于連接失敗,可以在從節(jié)點(diǎn)執(zhí)行 info replication 查看 master_link_down_since_seconds 指標(biāo),它會記錄與主節(jié)點(diǎn)連接失敗的系統(tǒng)時(shí)間。從節(jié)點(diǎn)連接主節(jié)點(diǎn)失敗時(shí)也會每秒打印如下日志,方便發(fā)現(xiàn)問題:

# Error condition on socket for SYNC: {socket_error_reason}

3)發(fā)送 ping 命令。
連接建立成功后從節(jié)點(diǎn)發(fā)送 ping 請求進(jìn)行首次通信,ping 請求主要目的如下:
·檢測主從之間網(wǎng)絡(luò)套接字是否可用。
·檢測主節(jié)點(diǎn)當(dāng)前是否可接受處理命令。
如果發(fā)送 ping 命令后,從節(jié)點(diǎn)沒有收到主節(jié)點(diǎn)的 pong 回復(fù)或者超時(shí),比如網(wǎng)絡(luò)超時(shí)或者主節(jié)點(diǎn)正在阻塞無法響應(yīng)命令,從節(jié)點(diǎn)會斷開復(fù)制連接,下次定時(shí)任務(wù)會發(fā)起重連。

從節(jié)點(diǎn)發(fā)送的 ping 命令成功返回,Redis 打印如下日志,并繼續(xù)后續(xù)復(fù)制流程:

4)權(quán)限驗(yàn)證。如果主節(jié)點(diǎn)設(shè)置了 requirepass 參數(shù),則需要密碼驗(yàn)證,從節(jié)點(diǎn)必須配置 masterauth 參數(shù)保證與主節(jié)點(diǎn)相同的密碼才能通過驗(yàn)證;如果驗(yàn)證失敗復(fù)制將終止,從節(jié)點(diǎn)重新發(fā)起復(fù)制流程。

5)同步數(shù)據(jù)集。主從復(fù)制連接正常通信后,對于首次建立復(fù)制的場景,主節(jié)點(diǎn)會把持有的數(shù)據(jù)全部發(fā)送給從節(jié)點(diǎn),這部分操作是耗時(shí)最長的步驟。

6)命令持續(xù)復(fù)制。當(dāng)主節(jié)點(diǎn)把當(dāng)前的數(shù)據(jù)同步給從節(jié)點(diǎn)后,便完成了復(fù)制的建立流程。接下來主節(jié)點(diǎn)會持續(xù)地把寫命令發(fā)送給從節(jié)點(diǎn),保證主從數(shù)據(jù)一致性。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/30158.html

相關(guān)文章

  • 那一天,我被Redis主從架構(gòu)支配的恐懼

    摘要:面試官要不你來講講你最近在看的點(diǎn)唄可以拉出來一起討論下今天我也不知道要問什么候選者最近在看相關(guān)的內(nèi)容面試官嗯,我記得已經(jīng)問過的基礎(chǔ)和持久化了面試官要不你來講講你公司的是什么架構(gòu)的咯候選者我前公司的架構(gòu)是分片集群,使用的是層來對進(jìn)行分流到不同面試官:要不你來講講你最近在看的點(diǎn)唄?可以拉出來一起討論下(今天我也不知道要問什么)候選者:最近在看「Redis」相關(guān)的內(nèi)容面試官:嗯,我記得已經(jīng)問過Re...

    curried 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<