0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

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

電子工程師 ? 來(lái)源:lp ? 2019-03-12 15:24 ? 次閱讀

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

概述

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

面臨問(wèn)題

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

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

解決辦法

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

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

主從復(fù)制

什么是主從復(fù)制

主從復(fù)制,是指將一臺(tái)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)情況下,每臺(tái)Redis服務(wù)器都是主節(jié)點(diǎn);且一個(gè)主節(jié)點(diǎn)可以有多個(gè)從節(jié)點(diǎn)(或沒(méi)有從節(jié)點(diǎn)),但一個(gè)從節(jié)點(diǎn)只能有一個(gè)主節(jié)點(diǎn)。

主從復(fù)制的作用

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

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

3、負(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ù)載;尤其是在寫少讀多的場(chǎng)景下,通過(guò)多個(gè)從節(jié)點(diǎn)分擔(dān)讀負(fù)載,可以大大提高Redis服務(wù)器的并發(fā)量。

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

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

主從復(fù)制啟用

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

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

2、啟動(dòng)命令:redis-server啟動(dòng)命令后加入 --slaveof。

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

通過(guò) info replication 命令可以看到復(fù)制的一些信息。

主從復(fù)制原理

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

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

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

1、保存主節(jié)點(diǎn)(master)信息

執(zhí)行 slaveof 后 Redis 會(huì)打印如下日志:

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

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

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

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

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

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

#ErrorconditiononsocketforSYNC:{socket_error_reason}

3、發(fā)送 ping 命令

連接建立成功后從節(jié)點(diǎn)發(fā)送 ping 請(qǐng)求進(jìn)行首次通信, ping 請(qǐng)求主要目的如下:

檢測(cè)主從之間網(wǎng)絡(luò)套接字是否可用。

檢測(cè)主節(jié)點(diǎn)當(dāng)前是否可接受處理命令。

如果發(fā)送 ping 命令后,從節(jié)點(diǎn)沒(méi)有收到主節(jié)點(diǎn)的 pong 回復(fù)或者超時(shí),比如網(wǎng)絡(luò)超時(shí)或者主節(jié)點(diǎn)正在阻塞無(wú)法響應(yīng)命令,從節(jié)點(diǎn)會(huì)斷開(kāi)復(fù)制連接,下次定時(shí)任務(wù)會(huì)發(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)相同的密碼才能通過(guò)驗(yàn)證。如果驗(yàn)證失敗復(fù)制將終止,從節(jié)點(diǎn)重新發(fā)起復(fù)制流程。

5、同步數(shù)據(jù)集

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

6、命令持續(xù)復(fù)制

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • API
    API
    +關(guān)注

    關(guān)注

    2

    文章

    1501

    瀏覽量

    62025
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    3799

    瀏覽量

    64395
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    375

    瀏覽量

    10878

原文標(biāo)題:Redis 主從復(fù)制以及主從復(fù)制原理

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開(kāi)發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Redis主從復(fù)制的作用和步驟

    Redis青銅修煉手冊(cè)(五) --- Redis主從復(fù)制
    發(fā)表于 06-27 07:20

    mysql的主從復(fù)制

    mysql 主從復(fù)制
    發(fā)表于 04-28 14:30

    基于mycat的Mysql主從復(fù)制讀寫分離全攻略

    基于mycat的Mysql主從復(fù)制讀寫分離全攻略
    發(fā)表于 09-08 10:10 ?4次下載
    基于mycat的Mysql<b class='flag-5'>主從復(fù)制</b>讀寫分離全攻略

    詳解Redis主從復(fù)制和哨兵機(jī)制

    Redis主從復(fù)制主要有兩個(gè)角色,主機(jī)(master)對(duì)外提供讀寫功能,從機(jī)(slave)對(duì)外只提供讀功能,主機(jī)定期把數(shù)據(jù)同步到從機(jī)上保證數(shù)據(jù)一致性。
    的頭像 發(fā)表于 05-03 18:14 ?1956次閱讀
    詳解<b class='flag-5'>Redis</b><b class='flag-5'>主從復(fù)制</b>和哨兵機(jī)制

    利用MySQL進(jìn)行一主一從的主從復(fù)制

    本文講述了如何使用MyBatisPlus+ShardingSphereJDBC進(jìn)行讀寫分離,以及利用MySQL進(jìn)行一主一從的主從復(fù)制。
    的頭像 發(fā)表于 07-28 09:47 ?1039次閱讀

    談?wù)?b class='flag-5'>Redis怎樣配置實(shí)現(xiàn)主從復(fù)制?

    之前總結(jié)過(guò)redis的持久化機(jī)制:深度剖析Redis持久化機(jī)制,持久化機(jī)制主要解決redis數(shù)據(jù)單機(jī)備份問(wèn)題;redis的高可用需要考慮數(shù)據(jù)的多機(jī)備份,多機(jī)備份通過(guò)
    發(fā)表于 01-31 11:31 ?667次閱讀

    MySQL主從復(fù)制原理詳解

    簡(jiǎn)單講,MySQL主從復(fù)制就是數(shù)據(jù)寫入一臺(tái)服務(wù)器(主服務(wù)器)后,同時(shí)還會(huì)額外寫入另外的服務(wù)器(從服務(wù)器)。也就是說(shuō)數(shù)據(jù)會(huì)寫多份,這樣做的目的主要有兩個(gè):
    的頭像 發(fā)表于 02-06 10:27 ?1090次閱讀

    一個(gè)操作把MySQL主從復(fù)制整崩了

    最近公司某項(xiàng)目上反饋mysql主從復(fù)制失敗,被運(yùn)維部門記了一次大過(guò),影響到了項(xiàng)目的驗(yàn)收推進(jìn),那么究竟是什么原因?qū)е碌哪???b class='flag-5'>主從復(fù)制的原理又是什么呢?本文就對(duì)排查分析的過(guò)程做一個(gè)記錄。
    的頭像 發(fā)表于 05-11 11:14 ?549次閱讀
    一個(gè)操作把MySQL<b class='flag-5'>主從復(fù)制</b>整崩了

    聊聊RocketMQ的主從復(fù)制

    RocketMQ 主從復(fù)制是 RocketMQ 高可用機(jī)制之一,數(shù)據(jù)可以從主節(jié)點(diǎn)復(fù)制到一個(gè)或多個(gè)從節(jié)點(diǎn)。
    的頭像 發(fā)表于 07-04 09:42 ?630次閱讀
    聊聊RocketMQ的<b class='flag-5'>主從復(fù)制</b>

    什么是Redis主從復(fù)制

    Redis主從復(fù)制 來(lái)自靈魂的拷問(wèn):什么是Redis主從復(fù)制? 簡(jiǎn)言之就是: 主對(duì)外從對(duì)內(nèi),主可寫從不可寫 主掛了,從不可為主 看下面的圖加深下理解: 對(duì),你沒(méi)看錯(cuò),
    的頭像 發(fā)表于 10-09 15:09 ?422次閱讀
    什么是<b class='flag-5'>Redis</b><b class='flag-5'>主從復(fù)制</b>

    mysql主從復(fù)制三種模式

    MySQL主從復(fù)制是一種常見(jiàn)的數(shù)據(jù)同步方式,它可以實(shí)現(xiàn)將一個(gè)數(shù)據(jù)庫(kù)的更改同步到其他多個(gè)數(shù)據(jù)庫(kù)的功能。主從復(fù)制可以提高數(shù)據(jù)庫(kù)的可用性和性能,以及提供故障恢復(fù)和數(shù)據(jù)備份的支持。在MySQL中,有三種
    的頭像 發(fā)表于 11-16 14:04 ?1546次閱讀

    mysql主從復(fù)制主要有幾種模式

    MySQL主從復(fù)制是MySQL數(shù)據(jù)庫(kù)中常用的一種數(shù)據(jù)復(fù)制方式,用于實(shí)現(xiàn)數(shù)據(jù)的備份、負(fù)載均衡、故障恢復(fù)等目的。主從復(fù)制主要有以下幾種模式: 異步復(fù)制 異步
    的頭像 發(fā)表于 11-16 14:15 ?1175次閱讀

    mysql主從復(fù)制的原理

    MySQL主從復(fù)制是一種數(shù)據(jù)庫(kù)復(fù)制技術(shù),它允許將一個(gè)MySQL數(shù)據(jù)庫(kù)的更新操作自動(dòng)復(fù)制到其他MySQL數(shù)據(jù)庫(kù)上的過(guò)程。主要通過(guò)MySQL的binlog(二進(jìn)制日志)和relay log(中繼日志)來(lái)
    的頭像 發(fā)表于 11-16 14:18 ?492次閱讀

    mysql主從復(fù)制 混合類型的復(fù)制

    使用行級(jí)復(fù)制和語(yǔ)句級(jí)復(fù)制。本文將詳細(xì)介紹MySQL主從復(fù)制的概念、原理、配置步驟以及優(yōu)缺點(diǎn),并重點(diǎn)討論混合類型復(fù)制的實(shí)現(xiàn)和應(yīng)用。希望通過(guò)本文
    的頭像 發(fā)表于 11-16 14:20 ?559次閱讀

    配置MySQL主從復(fù)制和讀寫分離

    配置MySQL主從復(fù)制和讀寫分離
    的頭像 發(fā)表于 10-23 11:44 ?450次閱讀
    配置MySQL<b class='flag-5'>主從復(fù)制</b>和讀寫分離