具体需求是这样的,
这里的Redis是做存储的,不只是做缓存,例如任务队列,用户动态等
一主多从的Redis实例集群,当主发生故障的时候,如何能:
1、自动选出一个新的主实例 2、不需要应用端修改配置,自动将写请求切换到这个新的主实例上
认证0级讲师
用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剔除,從從Redis裡選出一個新的主,修改其它從Redis slave of新主
無Proxy轉發功能,需要應用端自行修改設定連結到新的主
Redis Sentinel 發現主故障時,可以發送通知,這時需要客戶端能監聽到這個通知,透過Redis Sentinel 提供的API取得到新的主Redis位址 SENTINEL get-master-addr-by-name master-name
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實現選舉
用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轉發功能,需要應用端自行修改設定連結到新的主
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實現選舉