一、Sentinel介紹
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站制作、成都網(wǎng)站制作與策劃設(shè)計(jì),文峰網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:文峰等地區(qū)。文峰做網(wǎng)站價(jià)格咨詢:18982081108
之前騷了一波redis的簡介及應(yīng)用場景,今天試了下他的哨兵模式;
Sentinel是Redis的高可用性(HA)解決方案,由一個(gè)或多個(gè)Sentinel實(shí)例組成的Sentinel系統(tǒng)可以監(jiān)視任意多個(gè)主服務(wù)器,以及這些主服務(wù)器屬下的所有從服務(wù)器,
并在被監(jiān)視的主服務(wù)器進(jìn)行下線狀態(tài)時(shí),自動將下線主服務(wù)器屬下的某個(gè)從服務(wù)器升級為新的主服務(wù)器,然后由新的主服務(wù)器代替已下線的主服務(wù)器繼續(xù)處理命令請求。
Redis提供的sentinel(哨兵)機(jī)制,通過sentinel模式啟動redis后,自動監(jiān)控master/slave的運(yùn)行狀態(tài),基本原理是:心跳機(jī)制+投票裁決
監(jiān)控(Monitoring): Sentinel 會不斷地檢查你的主服務(wù)器和從服務(wù)器是否運(yùn)作正常。
提醒(Notification): 當(dāng)被監(jiān)控的某個(gè) Redis 服務(wù)器出現(xiàn)問題時(shí), Sentinel 可以通過 API 向管理員或者其他應(yīng)用程序發(fā)送通知。
自動故障遷移(Automatic failover): 當(dāng)一個(gè)主服務(wù)器不能正常工作時(shí), Sentinel 會開始一次自動故障遷移操作, 它會將失效主服務(wù)器的其中一個(gè)從服務(wù)器升級為新的主服務(wù)器,
并讓失效主服務(wù)器的其他從服務(wù)器改為復(fù)制新的主服務(wù)器; 當(dāng)客戶端試圖連接失效的主服務(wù)器時(shí), 集群也會向客戶端返回新主服務(wù)器的地址, 使得集群可以使用新主服務(wù)器代替失效服務(wù)器。
二、Redis Sentinel搭建
測試采用2個(gè)哨兵,1個(gè)主redis,2個(gè)從redis。
復(fù)制5份redis.windows.conf文件并重命名如下(開發(fā)者可根據(jù)自己的開發(fā)習(xí)慣進(jìn)行重命名):
master.6379.conf 配置:
port 6379
#設(shè)置連接密碼
requirepass grs
#連接密碼
masterauth grs
slave.6380.conf 配置:
port 6380
requirepass grs
masterauth grs
dbfilename dump6380.rdb
#配置master
slaveof 127.0.0.1 6379
slave.6381.conf 配置:
port 6381
requirepass grs
masterauth grs
dbfilename dump6381.rdb
#配置master
slaveof 127.0.0.1 6379
sentinel.63791.conf 配置(將原配置文件清空后添加如下內(nèi)容)(另一個(gè)一樣,只需要修改下端口):
port 63791
#主master,2個(gè)sentinel選舉成功后才有效,這里的master-1是名稱,在整合的時(shí)候需要一致,這里可以隨便更改
sentinel monitor master-1 127.0.0.1 6379 2
#判斷主master的掛機(jī)時(shí)間(毫秒),超時(shí)未返回正確信息后標(biāo)記為sdown狀態(tài)
sentinel down-after-milliseconds master-1 5000
#若sentinel在該配置值內(nèi)未能完成failover操作(即故障時(shí)master/slave自動切換),則認(rèn)為本次failover失敗。
sentinel failover-timeout master-1 18000
#身份認(rèn)證
sentinel auth-pass master-1 grs
#選項(xiàng)指定了在執(zhí)行故障轉(zhuǎn)移時(shí), 最多可以有多少個(gè)從服務(wù)器同時(shí)對新的主服務(wù)器進(jìn)行同步,這個(gè)數(shù)字越小,完成故障轉(zhuǎn)移所需的時(shí)間就越長
sentinel parallel-syncs master-1 1
這里有三個(gè)問題需要注意
第一,若通過redis-cli -h 127.0.0.1 -p 6379連接,無需改變配置文件,配置文件默認(rèn)配置為bind 127.0.0.1(只允許127.0.0.1連接訪問)
若通過redis-cli -h 192.168.180.78 -p 6379連接,需改變配置文件,配置信息為bind 127.0.0.1 192.168.180.78(只允許127.0.0.1和192.168.180.78訪問)或者將bind 127.0.0.1注釋掉(允許所有遠(yuǎn)程訪問)
第二,masterauth為所要連接的master服務(wù)器的requirepass,如果一個(gè)redis集群中有一個(gè)master服務(wù)器,兩個(gè)slave服務(wù)器,當(dāng)master服務(wù)器掛掉時(shí),sentinel哨兵會隨機(jī)選擇一個(gè)slave服務(wù)器充當(dāng)master服務(wù)器,鑒于這種機(jī)制,解決辦法是將所有的主從服務(wù)器的requirepass和masterauth都設(shè)置為一樣。
第三,sentinel monitor master-1 127.0.0.1 6379 2 行尾最后的一個(gè)2代表什么意思呢?我們知道,網(wǎng)絡(luò)是不可靠的,有時(shí)候一個(gè)sentinel會因?yàn)榫W(wǎng)絡(luò)堵塞而誤以為一個(gè)master redis已經(jīng)死掉了,當(dāng)sentinel集群式,解決這個(gè)問題的方法就變得很簡單,只需要多個(gè)sentinel互相溝通來確認(rèn)某個(gè)master是否真的死了,這個(gè)2代表,當(dāng)集群中有2個(gè)sentinel認(rèn)為master死了時(shí),才能真正認(rèn)為該master已經(jīng)不可用了。(sentinel集群中各個(gè)sentinel也有互相通信,通過gossip協(xié)議)。
按如下循序依次啟動服務(wù)
1、redis-server master.6379.conf
2、redis-server slave.6380.conf
3、redis-server slave.6381.conf
4、redis-server sentinel.63791.conf --sentinel(linux:redis-sentinel sentinel.63791.conf)
5、redis-server sentinel.63792.conf --sentinel(linux:redis-sentinel sentinel.63792.conf)
查看master狀態(tài):
查看slave狀態(tài):
查看sentinel狀態(tài):
驗(yàn)證redis sentinel的主從切換:
1、首先關(guān)閉主redis(6379)服務(wù)(shutdown)。
2、查看哨兵,發(fā)現(xiàn)端口號為6380的從服務(wù)變成了主服務(wù),sentinel自動完成了故障切換。
3、啟動剛才被shutdown的6379服務(wù)并查看,發(fā)現(xiàn)它變成了從服務(wù)。
到這 我搭建和演示就結(jié)束了
后續(xù)單機(jī)版 spring 整合使用慢慢玩吧,成功了再來