Redis有什麼好的自動故障轉移方案
PHP中文网
PHP中文网 2017-04-24 09:09:53
0
6
1044

具體需求是這樣的,

這裡的Redis是做儲存的,不只是做緩存,例如任務佇列,用戶動態等

一主多從的Redis實例集群,當主發生故障的時候,如何能:

1、自動選出一個新的主實例
2.不需要應用程式端修改配置,自動將寫入請求切換到這個新的主實例

PHP中文网
PHP中文网

认证0级讲师

全部回覆(6)
PHPzhong

用redis 2.8的sentinel就可以實現你的要求。

它的主要用途就是monitor你的master和slave,如果master出現因為某種故障導致Ping不通,
叢集的sentinel會透過設定結合演算法為你在slave裡選擇一個新的master
並且通知其他的slave和sentinel,
sentinel.conf中的相關設定都會自修改,redis.conf檔案也不需要你手動修改。
最初的master就淪為slave了。

你也不需要設定sentinel是否為叢集狀態,你只要在sentinel.conf中配置相同的monitor,如下:
sentinel monitor mymaster 127.0.0.1 6379 2
其中ip 和 port 相同,sentinel能透過流言協議(gossip protocols)把自己和其他sentinel統一成集群,
類似你不用告訴sentinel master有哪些slave一樣。
以上,還有問題可以再交流。

伊谢尔伦

補充一下:

Redis Sentinel方案

優勢

能自動的將主Redis剔除,從從Redis裡選出一個新的主,修改其它從Redis slave of新主

劣勢

無Proxy轉發功能,需要應用端自行修改設定連結到新的主

Redis Sentinel 發現主故障時,可以發送通知,這時需要客戶端能監聽到這個通知,透過Redis Sentinel
提供的API取得到新的主Redis位址

SENTINEL get-master-addr-by-name master-name

伊谢尔伦

twemproxy 是 Twitter 開源的 Redis Proxy。 Twitter 使用它將 Redis 擴展到了 105TB 內存,39MM QPS 和 1萬多的 Redis 實例。

http://highscalability.com/blog/2014/9/8/how-twitter-uses-redis-to-sca...

黄舟

推薦本互動電子書給你看看,可以邊看邊試試:http://book.hubwiz.com/55518c22032c78127cce2481

小葫芦

不修改客戶端的話,可以使用keepalived實作

洪涛

redis 3 cluster實現選舉

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板