具體需求是這樣的,
這裡的Redis是做儲存的,不只是做緩存,例如任務佇列,用戶動態等
一主多從的Redis實例集群,當主發生故障的時候,如何能:
1、自動選出一個新的主實例
2.不需要應用程式端修改配置,自動將寫入請求切換到這個新的主實例
PHPz2017-04-24 09:11:53
用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一樣。
以上,還有問題可以再交流。
伊谢尔伦2017-04-24 09:11:53
補充一下:
能自動的將主Redis剔除,從從Redis裡選出一個新的主,修改其它從Redis slave of新主
無Proxy轉發功能,需要應用端自行修改設定連結到新的主
Redis Sentinel 發現主故障時,可以發送通知,這時需要客戶端能監聽到這個通知,透過Redis Sentinel
提供的API取得到新的主Redis位址SENTINEL get-master-addr-by-name master-name
伊谢尔伦2017-04-24 09:11:53
twemproxy 是 Twitter 開源的 Redis Proxy。 Twitter 使用它將 Redis 擴展到了 105TB 內存,39MM QPS 和 1萬多的 Redis 實例。
http://highscalability.com/blog/2014/9/8/how-twitter-uses-redis-to-sca...