国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Redis 主從復(fù)制 + 哨兵模式 + Cluster 集群

這篇具有很好參考價(jià)值的文章主要介紹了Redis 主從復(fù)制 + 哨兵模式 + Cluster 集群。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

redis群集

redis群集有三種模式:

分別是主從同步/復(fù)制、哨兵模式、Cluster,下面會(huì)講解一下三種模式的工作方式,以及如何搭建cluster群集

????????主從復(fù)制:

主從復(fù)制是高可用Redis的基礎(chǔ),哨兵和集群都是在主從復(fù)制基礎(chǔ)上實(shí)現(xiàn)高可用的。主從復(fù)制主要實(shí)現(xiàn)了數(shù)據(jù)的多機(jī)備份,以及對(duì)于讀操作的負(fù)載均衡和簡(jiǎn)單的故障恢復(fù)。

????????缺陷:

故障恢復(fù)無法自動(dòng)化;寫操作無法負(fù)載均衡;存儲(chǔ)能力受到單機(jī)的限制。

????????哨兵模式:

在主從復(fù)制的基礎(chǔ)上,哨兵實(shí)現(xiàn)了自動(dòng)化的故障恢復(fù)。

????????缺陷:

寫操作無法負(fù)載均衡;存儲(chǔ)能力受到單機(jī)的限制;哨兵無法對(duì)從節(jié)點(diǎn)進(jìn)行自動(dòng)故障轉(zhuǎn)移,在讀寫分離場(chǎng)景下,從節(jié)點(diǎn)故障會(huì)導(dǎo)致讀服務(wù)不可用,需要對(duì)從節(jié)點(diǎn)做額外的監(jiān)控、切換操作。

????????集群:

通過集群,Redis解決了寫操作無法負(fù)載均衡,以及存儲(chǔ)能力受到單機(jī)限制的問題,實(shí)現(xiàn)了較為完善的高可用方案。

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

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

主從復(fù)制流程:

1、若啟動(dòng)一個(gè)Slave機(jī)器進(jìn)程,則它會(huì)向Master機(jī)器發(fā)送一個(gè)“sync command”命令,請(qǐng)求同步連接。

2、無論是第一次連接還是重新連接,Master機(jī)器都會(huì)啟動(dòng)一個(gè)后臺(tái)進(jìn)程,將數(shù)據(jù)快照保存到數(shù)據(jù)文件中(執(zhí)行rdb操作),同時(shí)Master還會(huì)記錄修改數(shù)據(jù)的所有命令并緩存在數(shù)據(jù)文件中。

3、后臺(tái)進(jìn)程完成緩存操作之后,Master機(jī)器就會(huì)向Slave機(jī)器發(fā)送數(shù)據(jù)文件,Slave端機(jī)器將數(shù)據(jù)文件保存到硬盤上,然后將其加載到內(nèi)存中,接著Master機(jī)器就會(huì)將修改數(shù)據(jù)的所有操作一并發(fā)送給Slave端機(jī)器。若Slave出現(xiàn)故障導(dǎo)致宕機(jī),則恢復(fù)正常后會(huì)自動(dòng)重新連接。

4、Master機(jī)器收到Slave端機(jī)器的連接后,將其完整的數(shù)據(jù)文件發(fā)送給Slave端機(jī)器,如果Mater同時(shí)收到多個(gè)Slave發(fā)來的同步請(qǐng)求,則Master會(huì)在后臺(tái)啟動(dòng)一個(gè)進(jìn)程以保存數(shù)據(jù)文件,然后將其發(fā)送給所有的Slave端機(jī)器,確保所有的Slave端機(jī)器都正常。
?

搭建Redis 主從復(fù)制

準(zhǔn)備服務(wù)器節(jié)點(diǎn)

Master節(jié)點(diǎn): 20.0.0.50
Slave1節(jié)點(diǎn): 20.0.0.120
Slave2節(jié)點(diǎn): 20.0.0.123

systemctl stop firewalld
setenforce 0

每臺(tái)服務(wù)器安裝Redis

安裝 Redis-----
yum install -y gcc gcc-c++ make

tar zxvf redis-5.0.7.tar.gz -C /opt/

wget -p /opt http://download.redis.io/releases/redis-5.0.9.tar.gz
cd /opt/redis-5.0.7/
make
make PREFIX=/usr/local/redis install
#由于Redis源碼包中直接提供了 Makefile 文件,所以在解壓完軟件包后,不用先執(zhí)行 ./configure 進(jìn)行配置,可直接執(zhí)行 make 與 make install 命令進(jìn)行安裝。

#執(zhí)行軟件包提供的 install_server.sh 腳本文件設(shè)置 Redis 服務(wù)所需要的相關(guān)配置文件
cd /opt/redis-5.0.7/utils
./install_server.sh
......                #一直回車至第五步
Please select the redis executable path [/usr/local/bin/redis-server] /usr/local/redis/bin/redis-server  	
#需要手動(dòng)修改為 /usr/local/redis/bin/redis-server ,注意要一次性正確輸入

#把redis的可執(zhí)行程序文件放入路徑環(huán)境變量的目錄中便于系統(tǒng)識(shí)別
ln -s /usr/local/redis/bin/* /usr/local/bin/

當(dāng) install_server.sh 腳本運(yùn)行完畢,Redis 服務(wù)就已經(jīng)啟動(dòng),默認(rèn)監(jiān)聽端口為 6379
netstat -natp | grep redis

修改 Master節(jié)點(diǎn) Redis 配置文件

vim /etc/redis/6379.conf   redis.conf
bind 0.0.0.0						#70行,修改監(jiān)聽地址為0.0.0.0
daemonize yes						#137行,開啟守護(hù)進(jìn)程
logfile /var/log/redis_6379.log		#172行,指定日志文件目錄
dir /var/lib/redis/6379				#264行,指定工作目錄
appendonly yes						#700行,開啟AOF持久化功能

#重啟redis
/etc/init.d/redis_6379 restart

修改Slave節(jié)點(diǎn) Redis 配置文件

bind 0.0.0.0						#70行,修改監(jiān)聽地址為0.0.0.0
daemonize yes						#137行,開啟守護(hù)進(jìn)程
logfile /var/log/redis_6379.log		#172行,指定日志文件目錄
dir /var/lib/redis/6379				#264行,指定工作目錄		
replicaof 20.0.0.50 6379        #288行,指定要同步的Master節(jié)點(diǎn)IP和端口
appendonly yes						#700行,開啟AOF持久化功能

#重啟redis
/etc/init.d/redis_6379 restart

驗(yàn)證主從效果

在Master節(jié)點(diǎn)上看日志

在Master節(jié)點(diǎn)上看日志:
tail -f /var/log/redis_6379.log 
Replica 20.0.0.120:6379 asks for synchronization
Replica 20.0.0.123:6379 asks for synchronization

在Master節(jié)點(diǎn)上驗(yàn)證從節(jié)點(diǎn)

[root@localhost ~]# redis-cli info replication
# Replication
role:master
connected_slaves:2
slave0:ip=20.0.0.123,port=6379,state=online,offset=378,lag=1
slave1:ip=20.0.0.120,port=6379,state=online,offset=378,lag=1
master_replid:e4e3276171b0167a79b2f0318fb935be3de040ca
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:378
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:378

Redis 哨兵模式

主從切換技術(shù)的方法是:當(dāng)服務(wù)器宕機(jī)后,需要手動(dòng)一臺(tái)從機(jī)切換為主機(jī),這需要人工干預(yù),不僅費(fèi)時(shí)費(fèi)力而且還會(huì)造成一段時(shí)間內(nèi)服務(wù)不可用。為了解決主從復(fù)制的缺點(diǎn),就有了哨兵機(jī)制。

哨兵的核心功能:在主從復(fù)制的基礎(chǔ)上,哨兵引入了主節(jié)點(diǎn)的自動(dòng)故障轉(zhuǎn)移。

哨兵模式原理:

哨兵(sentinel):是一個(gè)分布式系統(tǒng),用于對(duì)主從結(jié)構(gòu)中的每臺(tái)服務(wù)器進(jìn)行監(jiān)控,當(dāng)出現(xiàn)故障時(shí)通過投票機(jī)制選擇新的 Master并將所有slave連接到新的 Master。所以整個(gè)運(yùn)行哨兵的集群的數(shù)量不得少于3個(gè)節(jié)點(diǎn)

哨兵模式的作用:

監(jiān)控:哨兵會(huì)不斷地檢查主節(jié)點(diǎn)和從節(jié)點(diǎn)是否運(yùn)作正常。

自動(dòng)故障轉(zhuǎn)移:當(dāng)主節(jié)點(diǎn)不能正常工作時(shí),哨兵會(huì)開始自動(dòng)故障轉(zhuǎn)移操作,它會(huì)將失效主節(jié)點(diǎn)的其中一個(gè)從節(jié)點(diǎn)升級(jí)為新的主節(jié)點(diǎn),并讓其它從節(jié)點(diǎn)改為復(fù)制新的主節(jié)點(diǎn)。

通知(提醒):哨兵可以將故障轉(zhuǎn)移的結(jié)果發(fā)送給客戶端。

哨兵結(jié)構(gòu)由兩部分組成,哨兵節(jié)點(diǎn)和數(shù)據(jù)節(jié)點(diǎn):

哨兵節(jié)點(diǎn):哨兵系統(tǒng)由一個(gè)或多個(gè)哨兵節(jié)點(diǎn)組成,哨兵節(jié)點(diǎn)是特殊的redis節(jié)點(diǎn),不存儲(chǔ)數(shù)據(jù)。

數(shù)據(jù)節(jié)點(diǎn):主節(jié)點(diǎn)和從節(jié)點(diǎn)都是數(shù)據(jù)節(jié)點(diǎn)。

故障轉(zhuǎn)移機(jī)制:

1、由哨兵節(jié)點(diǎn)定期監(jiān)控發(fā)現(xiàn)主節(jié)點(diǎn)是否出現(xiàn)了故障

每個(gè)哨兵節(jié)點(diǎn)每隔1秒會(huì)向主節(jié)點(diǎn)、從節(jié)點(diǎn)及其它哨兵節(jié)點(diǎn)發(fā)送一次ping命令做一次心跳檢測(cè)。如果主節(jié)點(diǎn)在一定時(shí)間范圍內(nèi)不回復(fù)或者是回復(fù)一個(gè)錯(cuò)誤消息,那么這個(gè)哨兵就會(huì)認(rèn)為這個(gè)主節(jié)點(diǎn)主觀下線了(單方面的)。當(dāng)超過半數(shù)哨兵節(jié)點(diǎn)認(rèn)為該主節(jié)點(diǎn)主觀下線了,這樣就客觀下線了。

2、當(dāng)主節(jié)點(diǎn)出現(xiàn)故障,此時(shí)哨兵節(jié)點(diǎn)會(huì)通過Raft算法(選舉算法)實(shí)現(xiàn)選舉機(jī)制共同選舉出一個(gè)哨兵節(jié)點(diǎn)為leader,來負(fù)責(zé)處理主節(jié)點(diǎn)的故障轉(zhuǎn)移和通知。所以整個(gè)運(yùn)行哨兵的集群的數(shù)量不得少于3個(gè)節(jié)點(diǎn)。

3、由leader哨兵節(jié)點(diǎn)執(zhí)行故障轉(zhuǎn)移,過程如下:

將某一個(gè)從節(jié)點(diǎn)升級(jí)為新的主節(jié)點(diǎn),讓其它從節(jié)點(diǎn)指向新的主節(jié)點(diǎn);

若原主節(jié)點(diǎn)恢復(fù)也變成從節(jié)點(diǎn),并指向新的主節(jié)點(diǎn);

通知客戶端主節(jié)點(diǎn)已經(jīng)更換。

需要特別注意的是,客觀下線是主節(jié)點(diǎn)才有的概念;如果從節(jié)點(diǎn)和哨兵節(jié)點(diǎn)發(fā)生故障,被哨兵主觀下線后,不會(huì)再有后續(xù)的客觀下線和故障轉(zhuǎn)移操作。


主節(jié)點(diǎn)的選舉:

1、過濾掉不健康的(已下線的),沒有回復(fù)哨兵 ping 響應(yīng)的從節(jié)點(diǎn)。

2、選擇配置文件中從節(jié)點(diǎn)優(yōu)先級(jí)配置最高的。(replica-priority,默認(rèn)值為100)

3、選擇復(fù)制偏移量最大,也就是復(fù)制最完整的從節(jié)點(diǎn)。


哨兵的啟動(dòng)依賴于主從模式,所以須把主從模式安裝好的情況下再去做哨兵模式

搭建Redis 哨兵模式

Master節(jié)點(diǎn): 20.0.0.50
Slave1節(jié)點(diǎn): 20.0.0.120
Slave2節(jié)點(diǎn): 20.0.0.123

systemctl stop firewalld
setenforce 0

修改所有節(jié)點(diǎn) Redis 哨兵模式的配置文件

vim /opt/redis-5.0.7/sentinel.conf

protected-mode no								#17行,關(guān)閉保護(hù)模式

port 26379										#21行,Redis哨兵默認(rèn)的監(jiān)聽端口

daemonize yes									#26行,指定sentinel為后臺(tái)啟動(dòng)

logfile "/var/log/sentinel.log"					#36行,指定日志存放路徑

dir "/var/lib/redis/6379"						#65行,指定數(shù)據(jù)庫存放路徑

sentinel monitor mymaster 20.0.0.50 6379 2	    #84行,修改 指定該哨兵節(jié)點(diǎn)監(jiān)控20.0.0.50:6379這個(gè)主節(jié)點(diǎn),該主節(jié)點(diǎn)的名稱是mymaster,最后的2的含義與主節(jié)點(diǎn)的故障判定有關(guān):至少需要2個(gè)哨兵節(jié)點(diǎn)同意,才能判定主節(jié)點(diǎn)故障并進(jìn)行故障轉(zhuǎn)移

sentinel down-after-milliseconds mymaster 30000	#113行,判定服務(wù)器down掉的時(shí)間周期,默認(rèn)30000毫秒(30秒)

sentinel failover-timeout mymaster 180000		#146行,故障節(jié)點(diǎn)的最大超時(shí)時(shí)間為180000(180秒)

啟動(dòng)哨兵模式

先啟master,再啟slave
cd /opt/redis-5.0.7/
redis-sentinel sentinel.conf &

查看哨兵信息

redis-cli -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.50:6379,slaves=2,sentinels=3

故障模擬

#查看redis-server進(jìn)程號(hào):
ps -aux | grep redis
root      47670  0.1  0.2 156452  7916 ?        Ssl  08:44   0:06 /usr/local/redis/bin/redis-server 0.0.0.0:6379
root      51892  0.3  0.2 153892  7784 ?        Ssl  09:57   0:00 redis-sentinel *:26379 [sentinel]
root      52015  0.0  0.0 112724   988 pts/0    S+   09:59   0:00 grep --color=auto redis

#殺死 Master 節(jié)點(diǎn)上redis-server的進(jìn)程號(hào)
kill -9 47670 			#Master節(jié)點(diǎn)上redis-server的進(jìn)程號(hào)

驗(yàn)證結(jié)果

#查看日志
tail -f /var/log/sentinel.log
51891:X 08 Sep 2023 09:57:35.350 # Configuration loaded
51892:X 08 Sep 2023 09:57:35.365 * Increased maximum number of open files to 10032 (it was originally set to 1024).
51892:X 08 Sep 2023 09:57:35.366 * Running mode=sentinel, port=26379.
51892:X 08 Sep 2023 09:57:35.366 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
51892:X 08 Sep 2023 09:57:35.368 # Sentinel ID is 01c1463d0e4af8b0f149256f3c7956dfb263a26b
51892:X 08 Sep 2023 09:57:35.368 # +monitor master mymaster 20.0.0.50 6379 quorum 2
51892:X 08 Sep 2023 09:57:35.372 * +slave slave 20.0.0.123:6379 20.0.0.123 6379 @ mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 09:57:35.373 * +slave slave 20.0.0.120:6379 20.0.0.120 6379 @ mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 09:57:53.580 * +sentinel sentinel e269017c8c48e5cdb4c1498403f3161e9bc68f8f 20.0.0.120 26379 @ mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 09:58:03.089 * +sentinel sentinel aa1ff0e24686ff298b24a3e5123447a4f7486fdd 20.0.0.123 26379 @ mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 10:06:42.804 # +sdown master mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 10:06:42.905 # +odown master mymaster 20.0.0.50 6379 #quorum 2/2
51892:X 08 Sep 2023 10:06:42.905 # +new-epoch 1
51892:X 08 Sep 2023 10:06:42.905 # +try-failover master mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 10:06:42.911 # +vote-for-leader 01c1463d0e4af8b0f149256f3c7956dfb263a26b 1
51892:X 08 Sep 2023 10:06:42.912 # aa1ff0e24686ff298b24a3e5123447a4f7486fdd voted for aa1ff0e24686ff298b24a3e5123447a4f7486fdd 1
51892:X 08 Sep 2023 10:06:42.914 # e269017c8c48e5cdb4c1498403f3161e9bc68f8f voted for aa1ff0e24686ff298b24a3e5123447a4f7486fdd 1
51892:X 08 Sep 2023 10:06:43.543 # +config-update-from sentinel aa1ff0e24686ff298b24a3e5123447a4f7486fdd 20.0.0.123 26379 @ mymaster 20.0.0.50 6379
51892:X 08 Sep 2023 10:06:43.543 # +switch-master mymaster 20.0.0.50 6379 20.0.0.123 6379
51892:X 08 Sep 2023 10:06:43.544 * +slave slave 20.0.0.120:6379 20.0.0.120 6379 @ mymaster 20.0.0.123 6379
51892:X 08 Sep 2023 10:06:43.544 * +slave slave 20.0.0.50:6379 20.0.0.50 6379 @ mymaster 20.0.0.123 6379
51892:X 08 Sep 2023 10:07:13.558 # +sdown slave 20.0.0.50:6379 20.0.0.50 6379 @ mymaster 20.0.0.123 6379

查看當(dāng)前的哨兵信息

redis-cli -p 26379 info Sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=20.0.0.123:6379,slaves=2,sentinels=3

Redis 群集模式

集群,即Redis Cluster,是Redis 3.0開始引入的分布式存儲(chǔ)方案。

集群由多個(gè)節(jié)點(diǎn)(Node)組成,Redis的數(shù)據(jù)分布在這些節(jié)點(diǎn)中。集群中的節(jié)點(diǎn)分為主節(jié)點(diǎn)和從節(jié)點(diǎn):只有主節(jié)點(diǎn)負(fù)責(zé)讀寫請(qǐng)求和集群信息的維護(hù);從節(jié)點(diǎn)只進(jìn)行主節(jié)點(diǎn)數(shù)據(jù)和狀態(tài)信息的復(fù)制。

集群的作用,可以歸納為兩點(diǎn):

1、數(shù)據(jù)分區(qū):數(shù)據(jù)分區(qū)(或稱數(shù)據(jù)分片)是集群最核心的功能。
集群將數(shù)據(jù)分散到多個(gè)節(jié)點(diǎn),一方面突破了Redis單機(jī)內(nèi)存大小的限制,存儲(chǔ)容量大大增加;另一方面每個(gè)主節(jié)點(diǎn)都可以對(duì)外提供讀服務(wù)和寫服務(wù),大大提高了集群的響應(yīng)能力。
Redis單機(jī)內(nèi)存大小受限問題,在介紹持久化和主從復(fù)制時(shí)都有提及;例如,如果單機(jī)內(nèi)存太大,bgsave和bgrewriteaof的fork操作可能導(dǎo)致主進(jìn)程阻塞,主從環(huán)境下主機(jī)切換時(shí)可能導(dǎo)致從節(jié)點(diǎn)長(zhǎng)時(shí)間無法提供服務(wù),全量復(fù)制階段主節(jié)點(diǎn)的復(fù)制緩沖區(qū)可能溢出。

2、高可用:集群支持主從復(fù)制和主節(jié)點(diǎn)的自動(dòng)故障轉(zhuǎn)移(與哨兵類似);當(dāng)任一節(jié)點(diǎn)發(fā)生故障時(shí),集群仍然可以對(duì)外提供服務(wù)。

Redis集群的數(shù)據(jù)分片:

Redis集群引入了哈希槽的概念
Redis集群有16384個(gè)哈希槽(編號(hào)0-16383)
集群的每個(gè)節(jié)點(diǎn)負(fù)責(zé)一部分哈希槽
每個(gè)Key通過CRC16校驗(yàn)后對(duì)16384取余來決定放置哪個(gè)哈希槽,通過這個(gè)值,去找到對(duì)應(yīng)的插槽所對(duì)應(yīng)的節(jié)點(diǎn),然后直接自動(dòng)跳轉(zhuǎn)到這個(gè)對(duì)應(yīng)的節(jié)點(diǎn)上進(jìn)行存取操作

以3個(gè)節(jié)點(diǎn)組成的集群為例:

節(jié)點(diǎn)A包含0到5460號(hào)哈希槽
節(jié)點(diǎn)B包含5461到10922號(hào)哈希槽
節(jié)點(diǎn)C包含10923到16383號(hào)哈希槽

Redis集群的主從復(fù)制模型

集群中具有A、B、C三個(gè)節(jié)點(diǎn),如果節(jié)點(diǎn)B失敗了,整個(gè)集群就會(huì)因缺少5461-10922這個(gè)范圍的槽而不可以用。
為每個(gè)節(jié)點(diǎn)添加一個(gè)從節(jié)點(diǎn)A1、B1、C1整個(gè)集群便有三個(gè)Master節(jié)點(diǎn)和三個(gè)slave節(jié)點(diǎn)組成,在節(jié)點(diǎn)B失敗后,集群選舉B1位為的主節(jié)點(diǎn)繼續(xù)服務(wù)。當(dāng)B和B1都失敗后,集群將不可用。

搭建Redis 群集模式

redis的集群一般需要6個(gè)節(jié)點(diǎn),3主3從。方便起見,這里所有節(jié)點(diǎn)在同一臺(tái)服務(wù)器上模擬:
以端口號(hào)進(jìn)行區(qū)分:3個(gè)主節(jié)點(diǎn)端口號(hào):6001/6002/6003,對(duì)應(yīng)的從節(jié)點(diǎn)端口號(hào):6004/6005/6006。文章來源地址http://www.zghlxwxcb.cn/news/detail-705895.html

cd /etc/redis/
mkdir -p redis-cluster/redis600{1..6}

for i in {1..6}
do
cp /opt/redis-5.0.7/redis.conf /etc/redis/redis-cluster/redis600$i
cp /opt/redis-5.0.7/src/redis-cli /opt/redis-5.0.7/src/redis-server /etc/redis/redis-cluster/redis600$i
done

開啟群集功能:

#其他5個(gè)文件夾的配置文件以此類推修改,注意6個(gè)端口都要不一樣。
cd /etc/redis/redis-cluster/redis6001
vim redis.conf
#bind 127.0.0.1?? ??? ??? ??? ??? ??? ??? ?#69行,注釋掉bind 項(xiàng),默認(rèn)監(jiān)聽所有網(wǎng)卡
protected-mode no?? ??? ??? ??? ??? ??? ?#88行,修改,關(guān)閉保護(hù)模式
port 6001?? ??? ??? ??? ??? ??? ??? ??? ?#92行,修改,redis監(jiān)聽端口,
daemonize yes?? ??? ??? ??? ??? ??? ??? ?#136行,開啟守護(hù)進(jìn)程,以獨(dú)立進(jìn)程啟動(dòng)
cluster-enabled yes?? ??? ??? ??? ??? ??? ?#832行,取消注釋,開啟群集功能
cluster-config-file nodes-6001.conf?? ??? ?#840行,取消注釋,群集名稱文件設(shè)置
cluster-node-timeout 15000?? ??? ??? ??? ?#846行,取消注釋群集超時(shí)時(shí)間設(shè)置
appendonly yes?? ??? ??? ??? ??? ??? ??? ?#700行,修改,開啟AOF持久化

啟動(dòng)redis節(jié)點(diǎn)

分別進(jìn)入那六個(gè)文件夾,執(zhí)行命令:redis-server redis.conf ,來啟動(dòng)redis節(jié)點(diǎn)
cd /etc/redis/redis-cluster/redis6001
redis-server redis.conf

for d in {1..6}
do
cd /etc/redis/redis-cluster/redis600$d
redis-server redis.conf
done

#查看redis進(jìn)程
ps -aux | grep redis
root      51892  0.2  0.2 153892  7984 ?        Ssl  07:50   0:11 redis-sentinel *:26379 [sentinel]
root      54492  0.1  0.2 165160  9920 ?        Ssl  08:22   0:03 redis-server *:6001 [cluster]
root      54502  0.1  0.2 165160 10220 ?        Ssl  08:23   0:03 redis-server *:6002 [cluster]
root      54510  0.1  0.2 165160 10220 ?        Ssl  08:23   0:03 redis-server *:6003 [cluster]
root      54518  0.1  0.3 171304 14792 ?        Ssl  08:23   0:03 redis-server *:6004 [cluster]
root      54526  0.1  0.3 171304 15316 ?        Ssl  08:23   0:03 redis-server *:6005 [cluster]
root      54534  0.1  0.4 171304 18064 ?        Ssl  08:23   0:03 redis-server *:6006 [cluster]
root      57547  0.0  0.0 112728   988 pts/0    S+   08:59   0:00 grep --color=auto redis

啟動(dòng)集群

redis-cli --cluster create 20.0.0.50:6001 20.0.0.50:6002 20.0.0.50:6003 20.0.0.50:6004 20.0.0.50:6005 20.0.0.50:6006 --cluster-replicas 1

測(cè)試集群

redis-cli -h 20.0.0.50 -p 6001
20.0.0.50:6001> CLUSTER SLOTS
1) 1) (integer) 10923
   2) (integer) 16383
   3) 1) "20.0.0.50"
      2) (integer) 6003
      3) "d6f30edac088f0a02c9a12661633aff61093fc21"
   4) 1) "20.0.0.50"
      2) (integer) 6005
      3) "3b1c4f90bc43c6d622d8305de06e1fcb2a78b9e5"
2) 1) (integer) 0
   2) (integer) 5460
   3) 1) "20.0.0.50"
      2) (integer) 6001
      3) "6740c70dea7aaa1b4bf5a485c84cff5e5a977b15"
   4) 1) "20.0.0.50"
      2) (integer) 6006
      3) "bfc3e41e8e4bf51f816eb97b153224d8fb5647dc"
3) 1) (integer) 5461
   2) (integer) 10922
   3) 1) "20.0.0.50"
      2) (integer) 6002
      3) "69dacd52bdd5349275de061d4bdf680791a5ff8a"
   4) 1) "20.0.0.50"
      2) (integer) 6004
      3) "ecc68ea20df25a360a4a3ece7aeb6a87d554a9bd"
20.0.0.50:6001> 

到了這里,關(guān)于Redis 主從復(fù)制 + 哨兵模式 + Cluster 集群的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • redis的主從復(fù)制,哨兵和cluster集群

    目錄 一、redis的高可用 1)redis高可用的概念 2)Redis的高可用技術(shù) 二、redis主從復(fù)制 1)主從復(fù)制的作用 2)主從復(fù)制流程 三、redis一主二從的部署 實(shí)驗(yàn)組件 實(shí)驗(yàn)步驟 環(huán)境準(zhǔn)備 修改內(nèi)核參數(shù) 安裝 Redis 創(chuàng)建redis工作目錄 環(huán)境變量 定義systemd服務(wù)管理腳本 修改 Redis 配置文件(

    2024年02月13日
    瀏覽(23)
  • Redis高可用之主從復(fù)制、哨兵、cluster集群

    Redis高可用之主從復(fù)制、哨兵、cluster集群

    主從復(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)(或沒有從節(jié)點(diǎn)),但一個(gè)從

    2024年02月06日
    瀏覽(25)
  • DAY 68 redis高可用的主從復(fù)制、哨兵、cluster集群

    DAY 68 redis高可用的主從復(fù)制、哨兵、cluster集群

    在web服務(wù)器中,高可用是指服務(wù)器可以正常訪問的時(shí)間,衡量的標(biāo)準(zhǔn)是在多長(zhǎng)時(shí)間內(nèi)可以提供正常服務(wù)(99.9%、99.99%、99.999%等等)。 但是在Redis語境中,高可用的含義似乎要寬泛一些,除了保證提供正常服務(wù)(如主從分離、快速容災(zāi)技術(shù)),還需要考慮數(shù)據(jù)容量的擴(kuò)展、數(shù)據(jù)安

    2024年02月06日
    瀏覽(25)
  • Redis追本溯源(四)集群:主從模式、哨兵模式、cluster模式

    Redis追本溯源(四)集群:主從模式、哨兵模式、cluster模式

    Redis 有多種集群搭建方式,比如,主從模式、哨兵模式、Cluster 模式。 Redis 主從模式還解決了單點(diǎn)的問題。Redis 主庫在進(jìn)行修改操作的時(shí)候,會(huì)把相應(yīng)的寫入命令近乎實(shí)時(shí)地同步給從庫,從庫回放這些命令,就可以保證自己的數(shù)據(jù)與主庫保持一致。那么,當(dāng)主庫發(fā)生宕機(jī)的時(shí)

    2024年02月14日
    瀏覽(23)
  • redis集群和分片-Redis Cluster:分布式環(huán)境中的數(shù)據(jù)分片、主從復(fù)制和 Sentinel 哨兵

    當(dāng)涉及到 Redis 中的集群、分片、主從復(fù)制和 Sentinel 哨兵時(shí),這些是構(gòu)建分布式 Redis 環(huán)境中非常重要的概念和組件。下面詳細(xì)介紹這些概念以及它們?cè)诜植际江h(huán)境中的作用。 Redis Cluster 是 Redis 官方提供的分布式解決方案,用于管理和維護(hù)多個(gè) Redis 節(jié)點(diǎn)的分布式數(shù)據(jù)存儲(chǔ)。R

    2024年02月13日
    瀏覽(92)
  • redis7部署集群:包含主從模式、哨兵模式、Cluster集群模式等三種模式

    redis7部署集群:包含主從模式、哨兵模式、Cluster集群模式等三種模式

    前言: redis部署集群常見的一般有三種模式:主從模式,Sentinel(哨兵模式),Redis Cluster(高可用Cluster集群),根據(jù)不同的需求可自定義選擇部署方式。 Redis 主從模式(Replication) 優(yōu)點(diǎn): 數(shù)據(jù)備份:主節(jié)點(diǎn)的數(shù)據(jù)會(huì)復(fù)制到從節(jié)點(diǎn),提供了數(shù)據(jù)冗余和一定程度的故障恢復(fù)能力

    2024年01月20日
    瀏覽(30)
  • redis復(fù)制和分區(qū):主從復(fù)制、哨兵模式和集群模式

    在 Redis 中,復(fù)制和分區(qū)是用于數(shù)據(jù)冗余和性能擴(kuò)展的關(guān)鍵特性。以下是主從復(fù)制、哨兵模式和集群模式的工作原理的簡(jiǎn)要概述: 主從復(fù)制 (Replication) 基本概念 :Redis 的主從復(fù)制功能允許多個(gè) Redis 服務(wù)器具有相同的數(shù)據(jù)副本。這在讀取操作的負(fù)載均衡、數(shù)據(jù)備份、災(zāi)難恢復(fù)等

    2024年01月20日
    瀏覽(25)
  • Redis三種模式——主從復(fù)制,哨兵模式,集群

    Redis三種模式——主從復(fù)制,哨兵模式,集群

    目錄 一、主從復(fù)制 ?1.1主從復(fù)制的概念 ??1.2Redis主從復(fù)制作用 ?1.2.1數(shù)據(jù)冗余 ?1.2.2故障恢復(fù) ??1.2.3負(fù)載均衡 ?1.2.4高可用基石 ?1.3Redis主從復(fù)制流程 ???1.4部署Redis 主從復(fù)制 1.4.1.環(huán)境部署 ?1.4.2.所有服務(wù)器都先關(guān)閉防火墻 ?1.4.3.所有服務(wù)器都安裝Redis ?1.4.4修改Master主節(jié)點(diǎn)

    2024年02月14日
    瀏覽(28)
  • Redis 的主從復(fù)制、哨兵模式、集群腦裂

    Redis 的主從復(fù)制、哨兵模式、集群腦裂

    主從復(fù)制 主從復(fù)制是 Redis 高可用服務(wù)最基礎(chǔ)的保證,將一臺(tái) Redis 主服務(wù)器,同步數(shù)據(jù)到多臺(tái) Redis 從服務(wù)器上,即一主多從的模式,且主從服務(wù)器之間采用的是「讀寫分離」的方式。 主服務(wù)器可以進(jìn)行讀寫操作,當(dāng)發(fā)生寫操作時(shí),自動(dòng)將寫操作同步給從服務(wù)器,而從服務(wù)器

    2024年02月10日
    瀏覽(17)
  • Redis(主從復(fù)制、哨兵模式、集群)概述及部署

    Redis(主從復(fù)制、哨兵模式、集群)概述及部署

    目錄 一、Redis高可用 二、redis持久化 2.1 持久化的功能 2.2 Redis 提供兩種方式進(jìn)行持久化 2.3?RDB 持久化 2.3.1 觸發(fā)條件 ?2.3.2 執(zhí)行流程 2.3.3?啟動(dòng)時(shí)加載 2.4?AOF持久化 2.5?執(zhí)行流程 2.5.1?命令追加(append) ?2.5.2 文件寫入(write)和文件同步(sync) 2.5.3?文件重寫(rewrite) 2.5.3.1?文件重寫的

    2024年02月15日
    瀏覽(19)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包