史上最全 Redis 高可用解決方案總結

本文主要針對 Redis 常見的幾種使用方式及其優缺點展開分析。
node

1、常見使用方式

Redis 的幾種常見使用方式包括:面試

1.Redis 單副本;redis

2.Redis 多副本(主從);數據庫

3.Redis Sentinel(哨兵);緩存

4.Redis Cluster;服務器

5.Redis 自研。數據結構

2、各類使用方式的優缺點

一、Redis 單副本

Redis 單副本,採用單個 Redis 節點部署架構,沒有備用節點實時同步數據,不提供數據持久化和備份策略,適用於數據可靠性要求不高的純緩存業務場景。架構


優勢:併發

架構簡單,部署方便;app

高性價比:緩存使用時無需備用節點(單實例可用性能夠用 supervisor 或 crontab 保證),固然爲了知足業務的高可用性,也能夠犧牲一個備用節點,但同時刻只有一個實例對外提供服務;

高性能。

缺點:

不保證數據的可靠性;

在緩存使用,進程重啓後,數據丟失,即便有備用的節點解決高可用性,可是仍然不能解決緩存預熱問題,所以不適用於數據可靠性要求高的業務;

高性能受限於單核 CPU 的處理能力(Redis 是單線程機制),CPU 爲主要瓶頸,因此適合操做命令簡單,排序、計算較少的場景。也能夠考慮用 Memcached 替代。

二、Redis 多副本(主從)

Redis 多副本,採用主從(replication)部署結構,相較於單副本而言最大的特色就是主從實例間數據實時同步,而且提供數據持久化和備份策略。主從實例部署在不一樣的物理服務器上,根據公司的基礎環境配置,能夠實現同時對外提供服務和讀寫分離策略。


優勢:

高可靠性:一方面,採用雙機主備架構,可以在主庫出現故障時自動進行主備切換,從庫提高爲主庫提供服務,保證服務平穩運行;另外一方面,開啓數據持久化功能和配置合理的備份策略,能有效的解決數據誤操做和數據異常丟失的問題;

讀寫分離策略:從節點能夠擴展主庫節點的讀能力,有效應對大併發量的讀操做。

缺點:

故障恢復複雜,若是沒有 RedisHA 系統(須要開發),當主庫節點出現故障時,須要手動將一個從節點晉升爲主節點,同時須要通知業務方變動配置,而且須要讓其它從庫節點去複製新主庫節點,整個過程須要人爲干預,比較繁瑣;

主庫的寫能力受到單機的限制,能夠考慮分片;

主庫的存儲能力受到單機的限制,能夠考慮 Pika;

原生複製的弊端在早期的版本中也會比較突出,如:Redis 複製中斷後,Slave 會發起 psync,此時若是同步不成功,則會進行全量同步,主庫執行全量備份的同時可能會形成毫秒或秒級的卡頓;又因爲 COW 機制,致使極端狀況下的主庫內存溢出,程序異常退出或宕機;主庫節點生成備份文件致使服務器磁盤 IO 和 CPU(壓縮)資源消耗;發送數 GB 大小的備份文件致使服務器出口帶寬暴增,阻塞請求,建議升級到最新版本。

三、Redis Sentinel(哨兵)

Redis Sentinel 是社區版本推出的原生高可用解決方案,其部署架構主要包括兩部分:Redis Sentinel 集羣和 Redis 數據集羣。

其中 Redis Sentinel 集羣是由若干 Sentinel 節點組成的分佈式集羣,能夠實現故障發現、故障自動轉移、配置中心和客戶端通知。Redis Sentinel 的節點數量要知足 2n+1(n>=1)的奇數個。



優勢:

Redis Sentinel 集羣部署簡單;

可以解決 Redis 主從模式下的高可用切換問題;

很方便實現 Redis 數據節點的線形擴展,輕鬆突破 Redis 自身單線程瓶頸,可極大知足 Redis 大容量或高性能的業務需求;

能夠實現一套 Sentinel 監控一組 Redis 數據節點或多組數據節點。

缺點:

部署相對 Redis 主從模式要複雜一些,原理理解更繁瑣;

資源浪費,Redis 數據節點中 slave 節點做爲備份節點不提供服務;

Redis Sentinel 主要是針對 Redis 數據節點中的主節點的高可用切換,對 Redis 的數據節點作失敗斷定分爲主觀下線和客觀下線兩種,對於 Redis 的從節點有對節點作主觀下線操做,並不執行故障轉移。

不能解決讀寫分離問題,實現起來相對複雜。

建議:

若是監控同一業務,能夠選擇一套 Sentinel 集羣監控多組 Redis 數據節點的方案,反之選擇一套 Sentinel 監控一組 Redis 數據節點的方案。

sentinel monitor配置中的建議設置成 Sentinel 節點的一半加 1,當 Sentinel 部署在多個 IDC 的時候,單個 IDC 部署的 Sentinel 數量不建議超過(Sentinel 數量 – quorum)。

合理設置參數,防止誤切,控制切換靈敏度控制:

a. quorum

b. down-after-milliseconds 30000

c. failover-timeout 180000

d. maxclient

e. timeout

部署的各個節點服務器時間儘可能要同步,不然日誌的時序性會混亂。

Redis 建議使用 pipeline 和 multi-keys 操做,減小 RTT 次數,提升請求效率。

自行搞定配置中心(zookeeper),方便客戶端對實例的連接訪問。

四、Redis Cluster

Redis Cluster 是社區版推出的 Redis 分佈式集羣解決方案,主要解決 Redis 分佈式方面的需求,好比,當遇到單機內存,併發和流量等瓶頸的時候,Redis Cluster 能起到很好的負載均衡的目的。

Redis Cluster 集羣節點最小配置 6 個節點以上(3 主 3 從),其中主節點提供讀寫操做,從節點做爲備用節點,不提供請求,只做爲故障轉移使用。

Redis Cluster 採用虛擬槽分區,全部的鍵根據哈希函數映射到 0~16383 個整數槽內,每一個節點負責維護一部分槽以及槽所印映射的鍵值數據。


優勢:

無中心架構;

數據按照 slot 存儲分佈在多個節點,節點間數據共享,可動態調整數據分佈;

可擴展性:可線性擴展到 1000 多個節點,節點可動態添加或刪除;

高可用性:部分節點不可用時,集羣仍可用。經過增長 Slave 作 standby 數據副本,可以實現故障自動 failover,節點之間經過 gossip 協議交換狀態信息,用投票機制完成 Slave 到 Master 的角色提高;

下降運維成本,提升系統的擴展性和可用性。

缺點:

Client 實現複雜,驅動要求實現 Smart Client,緩存 slots mapping 信息並及時更新,提升了開發難度,客戶端的不成熟影響業務的穩定性。目前僅 JedisCluster 相對成熟,異常處理部分還不完善,好比常見的「max redirect exception」。

節點會由於某些緣由發生阻塞(阻塞時間大於 clutser-node-timeout),被判斷下線,這種 failover 是沒有必要的。

數據經過異步複製,不保證數據的強一致性。

多個業務使用同一套集羣時,沒法根據統計區分冷熱數據,資源隔離性較差,容易出現相互影響的狀況。

Slave 在集羣中充當「冷備」,不能緩解讀壓力,固然能夠經過 SDK 的合理設計來提升 Slave 資源的利用率。

Key 批量操做限制,如使用 mset、mget 目前只支持具備相同 slot 值的 Key 執行批量操做。對於映射爲不一樣 slot 值的 Key 因爲 Keys 不支持跨 slot 查詢,因此執行 mset、mget、sunion 等操做支持不友好。

Key 事務操做支持有限,只支持多 key 在同一節點上的事務操做,當多個 Key 分佈於不一樣的節點上時沒法使用事務功能。

Key 做爲數據分區的最小粒度,不能將一個很大的鍵值對象如 hash、list 等映射到不一樣的節點。

不支持多數據庫空間,單機下的 redis 能夠支持到 16 個數據庫,集羣模式下只能使用 1 個數據庫空間,即 db 0。

複製結構只支持一層,從節點只能複製主節點,不支持嵌套樹狀複製結構。

避免產生 hot-key,致使主庫節點成爲系統的短板。

避免產生 big-key,致使網卡撐爆、慢查詢等。

重試時間應該大於 cluster-node-time 時間。

Redis Cluster 不建議使用 pipeline 和 multi-keys 操做,減小 max redirect 產生的場景。

五、Redis 自研

Redis 自研的高可用解決方案,主要體如今配置中心、故障探測和 failover 的處理機制上,一般須要根據企業業務的實際線上環境來定製化。



優勢:

高可靠性、高可用性;

自主可控性高;

貼切業務實際需求,可縮性好,兼容性好。

缺點:

實現複雜,開發成本高;

須要創建配套的周邊設施,如監控,域名服務,存儲元數據信息的數據庫等;

維護成本高。

分享一份面試寶典《Java核心知識點整理.pdf》「,覆蓋了JVM、鎖、高併發、反射、Spring原理、微服務、Zookeeper、數據庫、數據結構等等」,還有Java208道面試題(含答案)加入羣(Java高級架構)705127209 便可免費獲取到!

相關文章
相關標籤/搜索