设为首页 收藏本站
查看: 1196|回复: 0

[经验分享] redis sentinel 主从切换(failover)解决方案、详细配置

[复制链接]
发表于 2018-11-6 10:24:46 | 显示全部楼层 |阅读模式
  redis sentinel 主从切换(failover)解决方案、详细配置
  
  网站的访问量慢慢上来了。为了网站的性能方面,开始用了redis做缓存策略。刚开始的时候,redis是一个单点,当一台机器岩机的时候,redis的 服务完全停止,这时就会影响其他服务的正常运行。费话不多说了,下面利用redis sentinel做一个主从切换的集群管理。做这个集群管理的时候,查过很多资料才完全了解,他是怎么做的。
  参考资料:http://redis.io/topics/sentinel 我也是看这篇文章。
  环境配置
  
  由于我这次配置没有太多的机器,我用了vagrant 去开了多台虚拟机。然后搭好了环境。
  redis的安装请参考:redis 简单官方脚本安装方法(linux)
  集群配置最少需要三台机器,那么我就三台虚拟机,三台虚拟机分别安装同样的redis的环境
  ip分配:

  •   192.168.9.17  (redis sentinel 集群监控)
  •   192.168.9.18  (redis 主)
  •   192.168.9.19  (redis 从)
  
  redis配置:
  主的redis配置文件,使用默认的配置文件就可以了,如果你需要设计其他参数
  从的redis配置文件,添加
  #从的redis配置文件,需要添加
vim /etc/redis/6379.conf  
slaveof 192.168.9.18 6379
  
  启动主从redis
#启动主redis(192.168.9.18)  
/etc/init.d/redis_6379.conf start
  
#启动从redis(192.168.9.19)
  
/etc/init.d/redis_6379.conf start
  
  查看主redis信息
#查看主redis的信息  
redis-cli -h 192.168.9.18 info Replication
  
# Replication
  
role:master #代表192.168.9.18:6379 这台redis是主
  
connected_slaves:1
  
slave0:192.168.9.18,6379,online
  
  查看从redis信息
#查看主redis的信息  
redis-cli -h 192.168.9.19 info Replication
  
# Replication
  
role:slave #代表192.168.9.18:6379 这台redis是主
  
master_host:192.168.9.18
  
master_port:6379
  
master_link_status:up
  
master_last_io_seconds_ago:4
  
master_sync_in_progress:0
  
slave_priority:100
  
slave_read_only:1
  
connected_slaves:0
  
  配置redis sentinel集群监控服务
  
  1.添加一份redis sentinel 配置文件
vim /etc/redis/sentinel.conf  
##redis-0
  
##sentinel实例之间的通讯端口
  
port 26379
  
#master1
  
sentinel monitor master1 192.168.9.18 6379 1
  
sentinel down-after-milliseconds master1 5000
  
sentinel failover-timeout master1 900000
  
sentinel can-failover master1 yes
  
sentinel parallel-syncs master1 2
  
#master2 可以添加多组主从的redis监听
  
...
  
..
  
..
  
  2.有配置文件了,那么启动redis sentinel做redis集群监听
redis-sentinel sentinel.conf --sentinel  
  好了,所有环境都搭好了。下面开始正式的演示
  
  1.正常演示

  •   把主的redis启动
  •   把从的redis启动
  •   把redis sentinel 集群监听启动
  观察redis sentinel 日志信息
DSC0000.jpg

  这里很清楚地看到,从的redis加入了集群
  [4925] 15 Oct 03:42:21.889 * +slave slave 192.168.9.19:6379 192.168.9.19 6379 @ master1 192.168.9.18 6379
  执行以下命令,查看redis主从信息
[root@localhost vagrant]# redis-cli -h 192.168.9.17 -p 26379 info Sentinel  
# Sentinel
  
sentinel_masters:1
  
sentinel_tilt:0
  
sentinel_running_scripts:0
  
sentinel_scripts_queue_length:0
  
master0:name=master1,status=ok,address=192.168.9.18:6379,slaves=1,sentinels=1
  那么表示一切都正常了。你的redis sentinel集群已经配置成功!
  
  2.故障演示
  
  2.1当主的redis 服务器岩机了,会发生什么情况呢?
  执行以下命令使用主的redis服务停止
redis-cli -h 192.168.9.18 -p 6379 shutdown #表示把192.168.9.18这台redis 关闭  关闭后,我们再查看redis sentinel 的日志情况
DSC0001.jpg

  这张图片很清晰地反应到,redis sentinel 监控到主的redis服务停止,然后自动把从的redis切换到主。
  再执行以下命令,查看redis主从信息
[root@localhost vagrant]# redis-cli -h 192.168.33.111 -p 26379 info Sentinel  
# Sentinel
  
sentinel_masters:1
  
sentinel_tilt:0
  
sentinel_running_scripts:0
  
sentinel_scripts_queue_length:0
  
master0:name=master1,status=ok,address=192.168.9.19:6379,slaves=1,sentinels=1
  把从已经升为主了。那么自动切换就已经成功了!
  
  2.2 当我们已经发现,一台redis发生故障了,可能会收到一些故障信息,那么再把服务已关闭的redis恢复服务状态,会发生怎么样的情况呢?
DSC0002.jpg

  redis sentinel 集群服务,会把上次主redis重新加入服务中,但是他再以不是主的redis了,变成从的reids。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-631423-1-1.html 上篇帖子: Redis监控技巧总结 下篇帖子: redis学习笔记之pipeline
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表