redis-sentinel 做HA

http://blog.csdn.net/gaogaoshan/article/details/41043685

基本介绍

本文基于redis-2.8.10和jedis2.4.2版本。

redis 2.8之后的版本 开始支持Sentinel监听客户端功能。使用1个或多个的Sentinel作为一个监听的集群。

后端N个(master+slave)组成一个redis集群。


Sentinel通过检测Redis的master实例是否存活,并在Redis master实例发生故障时,将Redis master的slave提升为master,

并在老的master重新加入到redis sentinel的群集之后,会被重新配置,作为新master的slave。

这意味着基于redis sentinel的HA群集是能够自我管理的!

应用通过sentinel可以动态的得到当前master的连接,而不是直接在应该中配置写死的master的IP和端口。

这样就避免了master,slave切换后应用配置的连接不可用的情况。

安装配置

[html] view plaincopy

  1. http://download.redis.io/releases/redis-2.8.17.tar.gz
  2. 1.安装redis:
  3. tar zxvf redis-2.8.17.tar.gz (要先安装tcl)
  4. cd redis-2.8.8
  5. (查看Liunx版本方式:getconf LONG_BIT)
  6. 如果是32位:make CFLAGS="-march=i686"
  7. 如果是64位:make
  8. 要是编译失败(make clean)
  9. cd src
  10. make test
  11. make install

[html] view plaincopy

  1. mkdir -p /opt/portal/redis/bin
  2. mkdir -p /opt/portal/redis/conf
  3. mkdir -p /opt/portal/redis/logs
  4. cd /opt/portal/redis/redis-2.8.8
  5. cp redis.conf sentinel.conf /opt/portal/redis/conf
  6. cd /opt/portal/redis/redis-2.8.8/src
  7. cp  redis-server redis-cli redis-sentinel redis-benchmark  mkreleasehdr.sh redis-check-aof redis-check-dump   /opt/portal/redis/bin
  8. 设置别名
  9. vi /etc/profile
  10. alias redis-server=‘/opt/portal/redis/bin/redis-server /opt/portal/redis/conf/redis.conf‘
  11. alias redis-cli=‘/opt/portal/redis/bin/redis-cli‘
  12. 使配置文件生效
  13. . /etc/profile

slave 的 redis  的redis.conf需要配置master的IP和端口# slaveof <masterip> <masterport>

Sentinel官方文档:官网:http://redis.io/topics/sentinel

[html] view plaincopy

  1. <span style="font-size:24px;">sentinel.conf主要有6个配置项</span>
  2. <span style="color:#ff0000;">port 26329
  3. sentinel monitor mymaster 192.168.14.191 6379 2</span>
  4. sentinel down-after-milliseconds mymaster 60000
  5. sentinel failover-timeout mymaster 180000
  6. sentinel parallel-syncs mymaster 1
  7. sentinel notification-script <master-name> <script-path>
  8. port: 指定sentinel的侦听端口(即与redis server或client建立tcp连接的端口)
  9. monitor: 指定sentinel要monitor的redis实例,包括一个redis实例的别名(alias)及redis实例的ip+port,<span style="color:#006600;">该行最后的数字2表示至少2个setinel实例同时检测到redis server异常时,才将redis server的状态判决为real fail。也即,若这里配置为2,但实际部署中sentinel只部署了1套,则即使redis实例已经挂掉,sentinel也不会给出任何警告。这一点需要特别引起注意。</span>
  10. down-after-milliseconds: 指定sentinel监控到redis实例持续异常多长时间后,会判决其状态为down。若实际业务需要sentinel尽快判决出redis实例异常,则可适当配小。
  11. failover-timeout: 若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。该配置有4个用途,具体可参考sentinel.conf中的说明,限于篇幅,此处不再赘述。
  12. parallel-syncs: 指定failover过程中,同时被sentinel reconfigure的最大slave实例数。由于reconfigure过程中,对应的slave会中断响应客户端请求,故为避免所有的slave同时不可用,该值需适当配小。
  13. notification-script: 指定sentinel检测到master-name指向的实例异常时,调用的报警脚本。该配置项可选,但线上系统建议配置。

测试

191,192上面各部署一个Sentinel监控同一个master。

192部署master,191部署slave(redis.conf 中配置master的地址 slave of 192.168.11.190 6379


启动redis,Sentinel

[html] view plaincopy

  1. nohup ./bin/redis-sentinel ./conf/sentinel.conf> ./logs/redis-sentinel.log 2>&1&
  2. redis-cli info 可以查看当前redis实例的基本信息
  3. redis-cli -p 26379  连接redis-sentinel客户端  info 查看master地址,有几个slave,有几个监控
  4. 动态添加需要监控的master
  5. 192.168.14.192:26381> sentinel monitor mymaster 192.168.14.193 6379 2
  6. 查看一个指定的master有那些slaves:
  7. 192.168.14.192:26379> sentinel slaves mymaster

[html] view plaincopy

  1. <span style="color:#3333ff;">192关闭master: redis-cli下shutdown </span>
  2. 在redis-sentinel.log中
  3. +sdown master mymaster 192.168.14.192 6379  监控到192down了
  4. +vote-for-leader bccb0d2d048a9a8497f87137a856add2ff57bceb 1 选举新的master
  5. +switch-master mymaster 192.168.14.192 6379 192.168.14.191 6379  将原来的master192 换成191
  6. +slave slave 192.168.14.192:6379 192.168.14.192 6379 @ mymaster 192.168.14.191 6379 192变成了191的slave
  7. redis-cli info Replication <span style="color:#3333ff;">191 变成role:master</span>
  8. <span style="color:#3333ff;">重新开启 192
  9. redis-cli info Replication 192 role:slave</span>
  10. <span style="color:#3333ff;">再把191 shutdown 192 又变回master了</span>

Spring配置文件&代码

[html] view plaincopy

  1. <bean id="sentinelConfiguration" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
  2. <property name="master">
  3. <bean class="org.springframework.data.redis.connection.RedisNode">
  4. <property name="name" value="mymaster"></property>
  5. </bean>
  6. </property>
  7. <property name="sentinels">
  8. <set>
  9. <bean class="org.springframework.data.redis.connection.RedisNode">
  10. <constructor-arg name="host" value="192.168.14.192"></constructor-arg>
  11. <constructor-arg name="port" value="26379"></constructor-arg>
  12. </bean>
  13. <bean class="org.springframework.data.redis.connection.RedisNode">
  14. <constructor-arg name="host" value="192.168.14.191"></constructor-arg>
  15. <constructor-arg name="port" value="26379"></constructor-arg>
  16. </bean>
  17. </set>
  18. </property>
  19. </bean>
  20. <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
  21. <constructor-arg name="sentinelConfig" ref="sentinelConfiguration"></constructor-arg>
  22. </bean>
  23. <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">
  24. <property name="connectionFactory" ref="connectionFactory" />
  25. </bean>

配置文件要懒加载,java-dao 要用getBean获取redisTemplate,getBean之前还要用Jedis jedis = new Jedis(ip, port);测试,不然redis连接不上,

[html] view plaincopy

  1. Sentinel会死循环的不断连接

sentinelConfiguration配置监听的列表

connectionFactory:从监听中获取当前的master

redisTemplate:到connectionFactory获取连接


[html] view plaincopy

  1. Long listFormRedis=redisTemplate.opsForList().size("login_record_list");
  2. String hostName=connectionFactory.getSentinelConnection().masters().iterator().next().getHost();
  3. System.out.println(listFormRedis);
  4. System.out.println(hostName);

master切换的时候应用的日志:

[html] view plaincopy

  1. It seems like server has closed the connection.; nested exception
  2. 2014-11-10 16:57:46 redis.clients.jedis.JedisSentinelPool initPool
  3. 信息: Created JedisPool to master at 192.168.14.191:6379
时间: 2025-01-16 00:40:13

redis-sentinel 做HA的相关文章

基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案

基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案 http://www.tuicool.com/articles/naeEJbv 基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案 时间 2014-02-21 15:15:17  IT社区推荐资讯 原文  http://itindex.net/detail/48192-redis-sentinel-redis Redis Sentinel是一个分布式系统,可以部署多个Se

基于Redis Sentinel的Redis集群(主从Sharding)高可用方案(转)

本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedis2.2.2及以上版本(强制),Redis2.8及以上版本(可选,Sentinel最早出现在Redis2.4中,Redis2.8中Sentinel更加稳定),Redis集群是以分片(Sharding)加主从的方式搭建,满足可扩展性的要求: Redis Sentinel介绍 Redis Sentinel是Redis官方提供的集群管理工具,主要有三大功能: 监控,能持续监控Redis的主从实例是否正常

(转)基于Redis Sentinel的Redis集群(主从&amp;Sharding)高可用方案

转载自:http://warm-breeze.iteye.com/blog/2020413 本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedis2.2.2及以上版本(强制),Redis2.8及以上版本(可选,Sentinel最早出现在Redis2.4中,Redis2.8中Sentinel更加稳定),Redis集群是以分片(Sharding)加主从的方式搭建,满足可扩展性的要求: Redis Sentinel介绍 Redis Sentinel是Re

redis sentinel 主从切换(failover)解决方案,详细配置

主从复制简单来说就是把一台redis数据库中的数据同步到另一台redis数据库,并且按照数据流向,数据的发送者我们称作master,数据的接受者我们称作slave(master/slave的划分并不是那么一定的,譬如B可以作为A的slave,但同时也可以作为C的master),下面就从slave和master的角度分别说明主从复制流程. 首先是slave端,对于slave端来说,主从复制主要经历四个阶段: 第一阶段:与master建立连接 第二阶段:向master发起同步请求(SYNC) 第三阶

Redis Sentinel实现的机制与原理详解

序言 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案.实际上这意味着你可以使用Sentinel模式创建一个可以不用人为干预而应对各种故障的Redis部署. 它的主要功能有以下几点 监控:Sentinel不断的检查master和slave是否正常的运行. 通知:如果发现某个redis节点运行出现问题,可以通过API通知系统管理员和其他的应用程序. 自动故障转移:能够进行自动切换.当一个master节点不可用时,能够选举出master的多个slave中的一个来作为新的ma

Redis Sentinel环境下的Key过期事件消息订阅

一.Redis Sentinel Sentinel是Redis 2.8之后官方发布的HA解决方案,通过Sentinel可以保障整个Redis系统的高可用性.当Redis系统中的Master在异常情况下停止服务后,若干Sentinel会及时察觉并主观判断Master down(Subjectively Down),并且随后由一定数量的Sentinel共同确定Master确实客观已down(Objectively Down),这个时候Sentinel们会选举出一个新的Master继续提供服务.Red

Redis Sentinel机制与用法(一)

概述 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如 master宕机了,Redis本身(包括它的很多客户端)都没有实现自动进行主备切换,而Redis-sentinel本身也是一个独立运行的进程,它 能监控多个master-slave集群,发现master宕机后能进行自懂切换. 它的主要功能有以下几点 不时地监控redis是否按照预期良好地运行; 如果发现某个redis节点运行出现状况,能够通知另外一个进程

Redis Sentinel 机制与用法(二)

概述 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如 master宕机了,Redis本身(包括它的很多客户端)都没有实现自动进行主备切换,而Redis-sentinel本身也是一个独立运行的进程,它 能监控多个master-slave集群,发现master宕机后能进行自懂切换. 它的主要功能有以下几点 不时地监控redis是否按照预期良好地运行; 如果发现某个redis节点运行出现状况,能够通知另外一个进程

Redis Sentinel机制与用法说明

本文来自:https://segmentfault.com/a/1190000002680804 概述 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如master宕机了,Redis本身(包括它的很多客户端)都没有实现自动进行主备切换,而Redis-sentinel本身也是一个独立运行的进程,它能监控多个master-slave集群,发现master宕机后能进行自动切换. 它的主要功能有以下几点 不时地监控r