搜尋

首頁  >  問答  >  主體

Redis有什麼好的自動故障轉移方案

具體需求是這樣的,

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

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

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

PHP中文网PHP中文网2796 天前1061

全部回覆(6)我來回復

  • PHPz

    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一樣。
    以上,還有問題可以再交流。

    回覆
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-24 09:11:53

    補充一下:

    Redis Sentinel方案

    優勢

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

    劣勢

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

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

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

    回覆
    0
  • 伊谢尔伦

    伊谢尔伦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...

    回覆
    0
  • 黄舟

    黄舟2017-04-24 09:11:53

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

    回覆
    0
  • 高洛峰

    高洛峰2017-04-24 09:11:53

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

    回覆
    0
  • PHP中文网

    PHP中文网2017-04-24 09:11:53

    redis 3 cluster實現選舉

    回覆
    0
  • 取消回覆