當(dāng)前位置:
首頁(yè) >
Redis搭建(二):主从复制
發(fā)布時(shí)間:2025/7/14
32
豆豆
生活随笔
收集整理的這篇文章主要介紹了
Redis搭建(二):主从复制
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
一、引言
Redis有三種集群模式:
- 第一個(gè)就是主從模式
- 第二種“哨兵”模式,在Redis 2.6版本開(kāi)始提供,2.8版本穩(wěn)定
- 第三種是Cluster集群模式,在Redis 3.x以后的版本才增加進(jìn)來(lái)的
二、主從介紹:
1. 工作原理:
?
- Slave啟動(dòng)并連接到Master之后,它將主動(dòng)發(fā)送一個(gè)SYNC命令。Master收到同步命令后將啟動(dòng)后臺(tái)存盤(pán)進(jìn)程,同時(shí)收集所有接收到的用于修改數(shù)據(jù)集的命令,在后臺(tái)進(jìn)程執(zhí)行完畢后,Master將傳送整個(gè)數(shù)據(jù)庫(kù)文件到Slave,以完成一次完全同步。
- Slave在接收到數(shù)據(jù)庫(kù)文件數(shù)據(jù)之后將其存盤(pán)并加載到內(nèi)存中。
- 此后,Master主節(jié)點(diǎn)繼續(xù)將所有已經(jīng)收集到的修改命令,和新的修改命令依次傳送給Slaves,Slave將在本次執(zhí)行這些數(shù)據(jù)修改命令,從而達(dá)到最終的數(shù)據(jù)同步。
- 如果Master和Slave之間的鏈接出現(xiàn)斷連現(xiàn)象,Slave可以自動(dòng)重連Master,但是在連接成功之后,一次完全同步將被自動(dòng)執(zhí)行。
2. 特點(diǎn):
- 同一個(gè)Master可以同步多個(gè)Slaves。
- Slave同樣可以接受其它Slaves的連接和同步請(qǐng)求,這樣可以有效的分載Master的同步壓力。因此我們可以將Redis的Replication架構(gòu)視為圖結(jié)構(gòu)。
- Master Server是以非阻塞的方式為Slaves提供服務(wù)。所以在Master-Slave同步期間,客戶(hù)端仍然可以提交查詢(xún)或修改請(qǐng)求。
- Slave Server同樣是以非阻塞的方式完成數(shù)據(jù)同步。在同步期間,如果有客戶(hù)端提交查詢(xún)請(qǐng)求,Redis則返回同步之前的數(shù)據(jù)。
- 為了分載Master的讀操作壓力,Slave服務(wù)器可以為客戶(hù)端提供只讀操作的服務(wù),寫(xiě)服務(wù)仍然必須由Master來(lái)完成。即便如此,系統(tǒng)的伸縮性還是得到了很大的提高。
- Master可以將數(shù)據(jù)保存操作交給Slaves完成,從而避免了在Master中要有獨(dú)立的進(jìn)程來(lái)完成此操作。
- 支持主從復(fù)制,主機(jī)會(huì)自動(dòng)將數(shù)據(jù)同步到從機(jī),可以進(jìn)行讀寫(xiě)分離。
3. 缺點(diǎn):
- master宕機(jī),需手動(dòng)修改配置、切換主從。
- Redis的主從復(fù)制采用全量復(fù)制,復(fù)制過(guò)程中主機(jī)會(huì)fork出一個(gè)子進(jìn)程對(duì)內(nèi)存做一份快照,并將子進(jìn)程的內(nèi)存快照保存為文件發(fā)送給從機(jī),這一過(guò)程需要確保主機(jī)有足夠多的空余內(nèi)存。若快照文件較大,對(duì)集群的服務(wù)能力會(huì)產(chǎn)生較大的影響,而且復(fù)制過(guò)程是在從機(jī)新加入集群或者從機(jī)和主機(jī)網(wǎng)絡(luò)斷開(kāi)重連時(shí)都會(huì)進(jìn)行,也就是網(wǎng)絡(luò)波動(dòng)都會(huì)造成主機(jī)和從機(jī)間的一次全量的數(shù)據(jù)復(fù)制,這對(duì)實(shí)際的系統(tǒng)運(yùn)營(yíng)造成了不小的麻煩。
- Redis較難支持在線(xiàn)擴(kuò)容,在集群容量達(dá)到上限時(shí)在線(xiàn)擴(kuò)容會(huì)變得很復(fù)雜。為避免這一問(wèn)題,運(yùn)維人員在系統(tǒng)上線(xiàn)時(shí)必須確保有足夠的空間,這對(duì)資源造成了很大的浪費(fèi)。
三、配置步驟:
1. 部署環(huán)境
- 一個(gè)master,兩個(gè)slave,master不需要修改
- 復(fù)制兩份slave配置文件,redis6380.conf和redis6380.conf,master使用redis.conf
2. 統(tǒng)一配置
daemonize yes //以后臺(tái)模式運(yùn)行
appendonly yes //默認(rèn)值是No,意思是不使用AOF增量持久化的方式,使用RDB全量持久化的方式。把No值改成Yes,使用AOF增量持久化的方式
3. slave的配置
- 修改pid和端口號(hào),與文件名對(duì)應(yīng)
- 如果設(shè)置了密碼,就要設(shè)置:masterauth <master-password>
- 配置slaveof,指定master地址
?
?
4. 啟動(dòng)所有Redis
redis-server redis.conf redis-server redis6380.conf redis-server redis6381.conf?
四、測(cè)試
1. 連接master,設(shè)置key
?
2. 查看集群信息,使用info replication命令
?
3. 連接slave,查看key信息,并測(cè)試寫(xiě)功能
?
?
轉(zhuǎn)載于:https://www.cnblogs.com/wslook/p/9152087.html
總結(jié)
以上是生活随笔為你收集整理的Redis搭建(二):主从复制的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python 字符串的魔法 day11(
- 下一篇: Redis可视化工具 Redis Des