`

[转] redis-sentinel 做HA

阅读更多
转自:http://blog.csdn.net/gaogaoshan/article/details/41043685
 

redis-sentinel 做HA

 2850人阅读 评论(0) 收藏 举报
 分类:
redis(4) 
 

目录(?)[+]

 

基本介绍

本文基于redis-2.8.10jedis2.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 plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. http://download.redis.io/releases/redis-2.8.17.tar.gz  
  2.   
  3. 1.安装redis:   
  4.   
  5. tar zxvf redis-2.8.17.tar.gz (要先安装tcl)  
  6.   
  7. cd redis-2.8.8   
  8.   
  9. (查看Liunx版本方式:getconf LONG_BIT)  
  10. 如果是32位:make CFLAGS="-march=i686"  
  11. 如果是64位:make  
  12.   
  13. 要是编译失败(make clean)  
  14.   
  15. cd src   
  16. make test  
  17. make install    
 
[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  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. 设置别名  
  10. vi /etc/profile  
  11. alias redis-server='/opt/portal/redis/bin/redis-server /opt/portal/redis/conf/redis.conf'  
  12. alias redis-cli='/opt/portal/redis/bin/redis-cli'  
  13. 使配置文件生效  
  14. . /etc/profile  



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

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

 

[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. <span style="font-size:24px;">sentinel.conf主要有6个配置项</span>  
  2.   
  3. <span style="color:#ff0000;">port 26329  
  4. sentinel monitor mymaster 192.168.14.191 6379 2</span>  
  5. sentinel down-after-milliseconds mymaster 60000  
  6. sentinel failover-timeout mymaster 180000  
  7. sentinel parallel-syncs mymaster 1  
  8. sentinel notification-script <master-name> <script-path>  
  9.   
  10.   
  11. port: 指定sentinel的侦听端口(即与redis server或client建立tcp连接的端口)  
  12. 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>  
  13. down-after-milliseconds: 指定sentinel监控到redis实例持续异常多长时间后,会判决其状态为down。若实际业务需要sentinel尽快判决出redis实例异常,则可适当配小。  
  14. failover-timeout: 若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。该配置有4个用途,具体可参考sentinel.conf中的说明,限于篇幅,此处不再赘述。  
  15. parallel-syncs: 指定failover过程中,同时被sentinel reconfigure的最大slave实例数。由于reconfigure过程中,对应的slave会中断响应客户端请求,故为避免所有的slave同时不可用,该值需适当配小。  
  16. 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 plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. nohup ./bin/redis-sentinel ./conf/sentinel.conf> ./logs/redis-sentinel.log 2>&1&  
  2.   
  3. redis-cli info 可以查看当前redis实例的基本信息  
  4. redis-cli -p 26379  连接redis-sentinel客户端  info 查看master地址,有几个slave,有几个监控  
  5.   
  6. 动态添加需要监控的master  
  7. 192.168.14.192:26381> sentinel monitor mymaster 192.168.14.193 6379 2   
  8. 查看一个指定的master有那些slaves:  
  9. 192.168.14.192:26379> sentinel slaves mymaster  

[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  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.   
  8. redis-cli info Replication <span style="color:#3333ff;">191 变成role:master</span>  
  9.   
  10.   
  11.   
  12. <span style="color:#3333ff;">重新开启 192  
  13. redis-cli info Replication 192 role:slave</span>  
  14.   
  15. <span style="color:#3333ff;">再把191 shutdown 192 又变回master了</span>  


Spring配置文件&代码

[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  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.   
  21. <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">  
  22.     <constructor-arg name="sentinelConfig" ref="sentinelConfiguration"></constructor-arg>  
  23. </bean>  
  24.   
  25.   
  26. <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">  
  27.     <property name="connectionFactory" ref="connectionFactory" />  
  28. </bean>  
 
配置文件要懒加载,java-dao 要用getBean获取redisTemplate,getBean之前还要用Jedis jedis = new Jedis(ip, port);测试,不然redis连接不上,
[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. Sentinel会死循环的不断连接  

sentinelConfiguration配置监听的列表
connectionFactory:从监听中获取当前的master
redisTemplate:到connectionFactory获取连接
 
[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. Long listFormRedis=redisTemplate.opsForList().size("login_record_list");  
  2. String hostName=connectionFactory.getSentinelConnection().masters().iterator().next().getHost();  
  3.   
  4. System.out.println(listFormRedis);  
  5. System.out.println(hostName);  


master切换的时候应用的日志:
[html] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  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  
分享到:
评论

相关推荐

    Windows环境Redis-Sentinel安装

    在Windows环境下安装Redis Sentinel是一个重要的步骤,因为它提供了高可用性(HA)解决方案,确保了主Redis服务器的故障能够被自动检测并切换到备选节点。Redis Sentinel系统是Redis集群中的监控、通知和故障转移...

    redis-sentinel-bin.7z

    Redis Sentinel是Redis的高可用性(HA)组件,它监控主从复制结构中的Redis服务器,当检测到主服务器出现故障时,Sentinel系统会自动将一个从服务器提升为主服务器,并通知其他从服务器进行切换,从而实现故障恢复。...

    redis-sentinel.tar.gz

    Redis Sentinel 是一个重要的组件,它是 Redis 高可用性(HA)解决方案的关键部分。这个压缩包“redis-sentinel.tar.gz”包含了一组脚本,旨在帮助用户设置和管理 Redis Sentinel 系统,确保数据的持久性和服务的...

    redis-sentinel集群及双机热备

    Redis Sentinel集群和双机热备是 Redis 高可用性(High Availability, HA)的重要组成部分,它们确保了在主节点故障时能够快速切换到备份节点,从而维持服务的连续性。以下将详细介绍这两个概念以及相关配置和操作。...

    redis-64.3.0.503-sentinel.zip

    Redis Sentinel 是一个重要的组件,它是 Redis 高可用性(HA)解决方案的关键部分。在这个名为 "redis-64.3.0.503-sentinel.zip" 的压缩包中,包含的是 Redis Sentinel 版本 64.3.0.503 的二进制文件和其他相关资源...

    redis-sentinel介绍.rar

    Redis Sentinel是Redis数据库系统中的一个组件,用于提供高可用性(High Availability,HA)解决方案。在Redis中,Sentinel系统负责监控主从集群的状态,自动处理主节点故障转移,并向应用提供服务发现功能。理解...

    redis-6.0.8-x64-for-windows-bin.zip

    Sentinel是Redis的一个高可用性(HA)解决方案,它可以监控主从复制集群的状态,自动故障转移,确保服务的连续性。 2. `run-cluster.bat`:同样是一个批处理脚本,用于启动Redis集群。Redis集群支持数据分区,可以...

    redis-6.2.6-cygwin.zip

    1. **startup-sentinel-26379.bat 和 startup-sentinel-26380.bat**:这两个批处理文件是用来启动Redis Sentinel服务的,Sentinel是Redis的高可用性(HA)解决方案,它可以监控主从复制集群,当主节点故障时自动进行...

    redis-sentienl-master-.pdf

    Redis Sentinel 是一个高可用性(HA)解决方案,用于监控、故障检测和自动故障转移,确保 Redis 集群中的主从服务保持稳定运行。在 Redis 集群中,Sentinel 系统扮演着关键角色,它能检测主服务器是否失效,并在必要...

    Redis-x64-7.0.4-win

    4. **sentinel.conf**:Sentinel 是 Redis 高可用性(HA)解决方案的一部分,用于监控、故障检测和自动故障转移。这个配置文件用于设置 Sentinel 系统的行为,例如监控的主从节点、故障切换条件等。 5. **cygwin1....

    Redis-x64-6.2.6 windows 64位版redis

    4. **sentinel.conf**: Redis Sentinel的配置文件,Sentinel系统用于实现高可用性(HA),监控主从节点的状态,自动故障转移,并管理集群配置。 5. **redis-check-rdb.exe** 和 **redis-check-aof.exe**: 这两个...

    Redis-7.0.2-x64 for Windows 64位版 Redis 7.0.2

    4. **sentinel.conf**: Redis Sentinel是Redis的一个高可用性(HA)解决方案,用于监控、故障检测和自动故障转移。这个配置文件用于设置Sentinel实例,确保主从Redis集群的稳定运行。 5. **cygwin1.dll**: 这是一个...

    redis-cluster:带有Docker的Sentinel的HA Redis集群

    Redis集群 带Docker Compose的Redis集群 使用Docker Compose设置带有哨兵的Redis集群。 该项目的灵感来自项目 先决条件 在测试环境中安装和 如果您使用的是Windows,请在“ git clone”之前执行以下命令以禁用将...

    redis-ha-client

    Redis-HA-Client是一款针对Redis高可用性的Java客户端库,专为处理Redis集群的故障转移和数据一致性问题而设计。这个库的目标是提供一个简单、高效且可靠的接口,使得应用程序在与Redis交互时能自动应对服务中断和...

    redis6.2.1,Windows 64版,bin.zip

    2. redis-sentinel.exe:这是Redis Sentinel的可执行文件,Sentinel是Redis的一个高可用性(HA)解决方案,负责监控主从集群的状态,自动故障转移,配置更新,并向应用提供API来查询集群状态。 3. redis-check-rdb....

    深入浅出Redis-redis哨兵集群.docx

    Redis Sentinel 是Redis的一个重要组件,它提供了高可用性(HA)解决方案,确保在主Redis服务器故障时能够自动切换到备份节点,从而保持服务的连续性。本文将深入探讨Redis Sentinel的集群原理、工作流程以及源码...

    redis-test:使用 sentinel 测试一些 redis 配置

    Redis Sentinel 是一个强大的工具,用于实现 Redis 集群的高可用性(HA)和故障转移。在这个名为 "redis-test" 的项目中,我们显然会探索如何使用 Sentinel 对 Redis 实例进行监控和管理,确保在主节点故障时能无缝...

    redis sentinel与redis cluster 集群配置

    Redis Sentinel是一个高可用性(HA)解决方案,它的主要任务是监控、提醒和自动故障转移。在 Sentinel 系统中,多个Sentinel节点会监控主Redis服务器和其对应的从服务器。当主服务器出现故障时,Sentinel节点会进行...

    Redis Sentinel实现高可用配置的详细步骤

    Redis Sentinel 是一个强大的工具,它提供了 Redis 集群的高可用性(HA)解决方案。在Redis中, Sentinel 系统负责监控主节点(master)的状态,如果检测到主节点故障, Sentinel 将自动进行故障转移(failover),...

Global site tag (gtag.js) - Google Analytics