用 redis-sentinel 做 redis 集群,如何实现当master挂掉后,不用修改程序中的配置

WBOY
풀어 주다: 2016-06-06 20:43:09
원래의
1030명이 탐색했습니다.

用 redis-sentinel 做 redis 集群,当 master 挂掉后,会将一个 slave 当做master,这样程序中的配置是不是必须改成新 master 的 ip 才行, 这样好麻烦,redis-sentinel 内置的有没有办法来解决这个问题,是不是必须用keepalive? 还有更好的解决办法么?

回复内容:

用 redis-sentinel 做 redis 集群,当 master 挂掉后,会将一个 slave 当做master,这样程序中的配置是不是必须改成新 master 的 ip 才行, 这样好麻烦,redis-sentinel 内置的有没有办法来解决这个问题,是不是必须用keepalive? 还有更好的解决办法么?

根据 Redis 关于 Sentinel Client 的文档,您的程序通常需要连接到 Sentinel,监听 failover 的事件(switch-master)。当 failover 发生时,您通常需要将你的 Redis 客户端重新连接到新的 master 并验证其身份(ROLE)。具体建议步骤在文档中有相当详细的描述。

另外,您可以选择支持 Sentinel 的 Redis 客户端库来替代现有的连接程序,以避免自己实现上述步骤的麻烦。有一些库已经支持这一功能了,请对应查找您所用的语言。

问, 在master发生故障时 sentinel 不能及时切换走master,是什么原因呢?求解
http://segmentfault.com/q/1010000002898134

在redis2.8以上版本已经不需要手动切换了,
1,当master挂掉后会随机切换一个slave为新的master。
2,当老的master重新启动后会自动成为slave加入集群。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿