经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Redis » 查看文章
redis哨兵机制
来源:cnblogs  作者:爱吃猫的鱼i  时间:2019/8/5 10:02:42  对本文有异议

哨兵机制存在的意义:

    为了实现redis故障转移的自动化。自动发现,自动转移。不需要人工参与。

 

用户管理多个Redis服务器,该系统执行三个任务:

  • 监控:哨兵会不间断的检查Master和Slave是否正常运行
  • 提醒:当被监控的某个Redis出现问题,哨兵通过API向管理员或者应用程序发送通知
  • 自动故障迁移:当一个Master不能正常工作,哨兵会开始一次故障迁移,然后将失效的Master的其中一个Slave升级为新的Master,并让失效的Master的其他Slave改为复制新的Master;当客户端尝试链接失效的Master时,集群会向客户端返回新的Master的地址,使集群可以使用Master代替失效的Master。

 

哨兵是一个分布式系统,可以在一个架构中运行多个哨兵进程,这些进程使用流言协议接收关于Master是否下线的信息,并使用投票协议决定是否执行自动故障迁移,以及选择哪个Slave作为新的Master

  • 每个哨兵会向其它哨兵、master、slave定时发送信息,确认对方是否活着, 如果对方在指定时间内未回应,则暂时认为对方已挂。
  • 若哨兵(sentinel)群多数sentinel认为某一master么响应,系统才认为该master死亡(down机),通过一定的vote算法,从剩下的slave节点,选一台提升为master,然后自动修改相关配置。

 

虽然哨兵释出为一个单独的可执行文件redis-sentinel,但实际上它只是一个运行在特殊模式下的Redis服务器,可以在启动一个普通的Redis服务器时通过给定 --sentinel 选项来启动哨兵。

原文链接:http://www.cnblogs.com/zwp-627/p/11296075.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号