Redis已經大量應用於各類互聯網架構場景中,其優異的性能,良好的操做性,以及大量的場景應用案例,使得Redis備受矚目。本文做者向你們介紹了一種Redis在非大集羣分佈式應用場景下的災備解決方案。一塊兒來品讀一下吧~
Redis是一個高性能的key-value非關係型數據庫,因爲其具備高性能的特性,支持高可用、持久化、多種數據結構、集羣等,使其脫穎而出,成爲經常使用的非關係型數據庫。
此外,Redis的使用場景也比較多。redis
wp-redis
,這個插件能以最快的速度加載你曾經瀏覽過的頁面。咱們常經過Reids的隊列功能作購買限制。好比到節假日或者推廣期間,進行一些活動,對用戶購買行爲進行限制,限制今天只能購買幾回商品或者一段時間內只能購買一次。也比較適合適用。數據庫
此外還有不少其它場景,Redis都表現的不錯。緩存
正是因爲Redis具有多種優良特新,且應用場景很是豐富,以致於Redis在各個公司都有它存在的身影。那麼隨之而來的問題和風險也就來了。Redis雖然應用場景豐富,但部分公司在實踐Redis應用的時候仍是相對保守使用單節點部署,那爲往後的維護帶來了安全風險。安全
在2015年的時候,曾處理過一個由於單點故障緣由致使的業務中斷問題。當時的Redis都未採用分佈式部署,採用單實例部署,並未考慮容災方面的問題。服務器
當時咱們經過Redis服務器作用戶購買優惠商品的行爲控制,但後來因爲未知緣由Redis節點的服務器宕機了,致使咱們沒法對用戶購買行爲進行控制,形成了用戶可以在一段時間內屢次購買優惠商品的行爲。數據結構
這種宕機事故能夠說已經對公司形成了不可挽回的損失了,安全風險問題很是嚴重,做爲當時運維這個系統的我來講有必要對這個問題進行修復和在架構上的改進。因而我開始瞭解決非分佈式應用下Redis單點故障方面的研究學習。架構
Redis主從複製如今應該是很廣泛了。經常使用的主從複製架構有以下兩種架構方案。運維
此時須要通過以下操做(假設提高Slave1爲Master):分佈式
1)在Slave1上執slaveof no one
命令提高Slave1爲新的Master節點。
2)在Slave1上配置爲可寫,這是由於大多數狀況下,都將slave配置只讀。
3)告訴Client端(也就是鏈接Redis的程序)新的Master節點的鏈接地址。
4)配置Slave2重新的Master進行數據複製。
架構方案二
當master出現故障後,Client能夠鏈接到Slave1上進行數據操做,可是Slave1就成了一個單點,就出現了常常要避免的單點故障(single point of failure)。以後須要通過以下操做:性能
1)在Slave1上執行slaveof no one命令提高Slave1爲新的Master節點
2)在Slave1上配置爲可寫,這是由於大多數狀況下,都將Slave配置只讀
3)配置Slave2重新的Master進行數據複製
能夠發現,不管是哪一種架構方案都須要人工干預來進行故障轉移(failover)。須要人工干預就增長了運維工做量,同時也對業務形成了巨大影響。這時候可使用Redis的高可用方案-Sentinel
Redis Sentinel爲Redis提供了高可用方案。從實踐方面來講,使用Redis Sentinel能夠建立一個無需人爲干預就能夠預防某些故障的Redis環境。
Redis Sentinel設計爲分佈式的架構,運行多個Sentinel進程來共同合做的。運行多個Sentinel進程合做,當多個Sentinel同一給定的master沒法再繼續提供服務,就會執行故障檢測,這會下降誤報的可能性。
Redis Sentinel在Redis高可用方案中主要做用有以下功能:
Sentinel集羣對自身和Redis主從複製進行監控。當發現Master節點出現故障時,會通過以下步驟:
2)Sentinel leader選取slave節點中的一個slave做爲新的Master節點。對slave選舉須要對slave進行選舉的方法以下:
a) 與master斷開時間
若是與master斷開的時間超過down-after-milliseconds(sentinel配置) * 10秒加上從sentinel斷定master不可用到sentinel開始執行故障轉移之間的時間,就認爲該slave不適合提高爲master。
b) slave優先級
每一個slave都有優先級,保存在redis.conf配置文件裏。若是優先級相同,則繼續進行。
c) 複製偏移位置
複製偏移紀錄着從master複製數據複製到哪裏,複製偏移越大代表從master接受的數據越多,若是複製偏移量也同樣,繼續進行選舉
d) Run ID
選舉具備最小Run ID的Slave做爲新的Master
流程圖以下:
![]()
使用sentinel實現了Redis的高可用,當master出現故障時,徹底無需人工干預便可實現故障轉移。避免了對業務的影響,提升了運維工做效率。
在部署sentinel的時候,建議使用奇數個sentinel節點,最少三個sentinel節點。
因爲sentinel知識點比較多,這裏僅給你們進行介紹,讓你們有個瞭解。
原文:https://www.sohu.com/a/167105...