转自:http://blog.csdn.net/gaogaoshan/article/details/41043685
分类:
redis(4)
版权声明:本文为博主原创文章,未经博主允许不得转载。
基本介绍
本文基于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切换后应用配置的连接不可用的情况。
安装配置
- http://download.redis.io/releases/redis-2.8.17.tar.gz
- 1.安装redis:
- tar zxvf redis-2.8.17.tar.gz (要先安装tcl)
- cd redis-2.8.8
- (查看Liunx版本方式:getconf LONG_BIT)
- 如果是32位:make CFLAGS="-march=i686"
- 如果是64位:make
- 要是编译失败(make clean)
- cd src
- make test
- make install
- mkdir -p /opt/portal/redis/bin
- mkdir -p /opt/portal/redis/conf
- mkdir -p /opt/portal/redis/logs
- cd /opt/portal/redis/redis-2.8.8
- cp redis.conf sentinel.conf /opt/portal/redis/conf
- cd /opt/portal/redis/redis-2.8.8/src
- cp redis-server redis-cli redis-sentinel redis-benchmark mkreleasehdr.sh redis-check-aof redis-check-dump /opt/portal/redis/bin
- 设置别名
- vi /etc/profile
- alias redis-server='/opt/portal/redis/bin/redis-server /opt/portal/redis/conf/redis.conf'
- alias redis-cli='/opt/portal/redis/bin/redis-cli'
- 使配置文件生效
- . /etc/profile
slave 的 redis 的redis.conf需要配置master的IP和端口# slaveof <masterip> <masterport>
Sentinel官方文档:官网:http://redis.io/topics/sentinel
- <span style="font-size:24px;">sentinel.conf主要有6个配置项</span>
- <span style="color:#ff0000;">port 26329
- sentinel monitor mymaster 192.168.14.191 6379 2</span>
- sentinel down-after-milliseconds mymaster 60000
- sentinel failover-timeout mymaster 180000
- sentinel parallel-syncs mymaster 1
- sentinel notification-script <master-name> <script-path>
- port: 指定sentinel的侦听端口(即与redis server或client建立tcp连接的端口)
- 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>
- down-after-milliseconds: 指定sentinel监控到redis实例持续异常多长时间后,会判决其状态为down。若实际业务需要sentinel尽快判决出redis实例异常,则可适当配小。
- failover-timeout: 若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。该配置有4个用途,具体可参考sentinel.conf中的说明,限于篇幅,此处不再赘述。
- parallel-syncs: 指定failover过程中,同时被sentinel reconfigure的最大slave实例数。由于reconfigure过程中,对应的slave会中断响应客户端请求,故为避免所有的slave同时不可用,该值需适当配小。
- 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
- nohup ./bin/redis-sentinel ./conf/sentinel.conf> ./logs/redis-sentinel.log 2>&1&
- redis-cli info 可以查看当前redis实例的基本信息
- redis-cli -p 26379 连接redis-sentinel客户端 info 查看master地址,有几个slave,有几个监控
- 动态添加需要监控的master
- 192.168.14.192:26381> sentinel monitor mymaster 192.168.14.193 6379 2
- 查看一个指定的master有那些slaves:
- 192.168.14.192:26379> sentinel slaves mymaster
- <span style="color:#3333ff;">192关闭master: redis-cli下shutdown </span>
- 在redis-sentinel.log中
- +sdown master mymaster 192.168.14.192 6379 监控到192down了
- +vote-for-leader bccb0d2d048a9a8497f87137a856add2ff57bceb 1 选举新的master
- +switch-master mymaster 192.168.14.192 6379 192.168.14.191 6379 将原来的master192 换成191
- +slave slave 192.168.14.192:6379 192.168.14.192 6379 @ mymaster 192.168.14.191 6379 192变成了191的slave
- redis-cli info Replication <span style="color:#3333ff;">191 变成role:master</span>
- <span style="color:#3333ff;">重新开启 192
- redis-cli info Replication 192 role:slave</span>
- <span style="color:#3333ff;">再把191 shutdown 192 又变回master了</span>
Spring配置文件&代码
- <bean id="sentinelConfiguration" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
- <property name="master">
- <bean class="org.springframework.data.redis.connection.RedisNode">
- <property name="name" value="mymaster"></property>
- </bean>
- </property>
- <property name="sentinels">
- <set>
- <bean class="org.springframework.data.redis.connection.RedisNode">
- <constructor-arg name="host" value="192.168.14.192"></constructor-arg>
- <constructor-arg name="port" value="26379"></constructor-arg>
- </bean>
- <bean class="org.springframework.data.redis.connection.RedisNode">
- <constructor-arg name="host" value="192.168.14.191"></constructor-arg>
- <constructor-arg name="port" value="26379"></constructor-arg>
- </bean>
- </set>
- </property>
- </bean>
- <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
- <constructor-arg name="sentinelConfig" ref="sentinelConfiguration"></constructor-arg>
- </bean>
- <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">
- <property name="connectionFactory" ref="connectionFactory" />
- </bean>
- Sentinel会死循环的不断连接
sentinelConfiguration配置监听的列表
connectionFactory:从监听中获取当前的master
redisTemplate:到connectionFactory获取连接
- Long listFormRedis=redisTemplate.opsForList().size("login_record_list");
- String hostName=connectionFactory.getSentinelConnection().masters().iterator().next().getHost();
- System.out.println(listFormRedis);
- System.out.println(hostName);
master切换的时候应用的日志:
- It seems like server has closed the connection.; nested exception
- 2014-11-10 16:57:46 redis.clients.jedis.JedisSentinelPool initPool
- 信息: Created JedisPool to master at 192.168.14.191:6379
相关推荐
redis-sentinel 就像他的名字一样,他是一个哨兵,监控 master 状态,如果超过规定时间没有响应,则自动进行主从切换,期间会有一段时间(决定于具体的配置参数)redis集群无法提供服务 。原理类似 mysql 的 MHA。...
redis-sentinel(哨兵机制)集群安装包,解压即可使用;在linux环境上快速搭建一个简单的基于哨兵模式的redis集群
Windows环境Redis-Sentinel安装,如需使用,请查看http://blog.csdn.net/u010648555/article/details/79430105 博文的介绍!
redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-...
dir "/usr/local/etc/redis6370" # 修改启动端口,依次修改为,26371,26372,26373 port 26370 # 添加关闭保护模式 protected-mode no # 修改sentinel monitor,这个不需要改动,都一样就可以,注意顺序,这个...
Bitnami包装的Redis(TM)Sentinel是什么? 免责声明:REDIS(r)是Redis Labs Ltd.... DR $ docker run --name redis-sentinel -e REDIS_MASTER_HOST=redis bitnami/redis-sentinel:latestDocker撰写$ curl -sSL htt
该资源是本人在学习redis过程中积累总结的经验以分享给大家:redis-sentinel高可用一键配置工具就是一键帮你从下载->安装->配置 好 redis 高可用的服务环境,省去了很多弯路,节约了更多的时间花在自己项目的主要...
redis-sentinel集群及双机热备
redis-5.0.14-1.el7.remi.x86_64.rpm安装包(含有部署手册) redis-5.0.14-1.el7.remi.x86_64.rpm安装包(含有部署手册) redis-5.0.14-1.el7.remi.x86_64.rpm安装包(含有部署手册) redis-5.0.14-1.el7.remi.x86_64.rpm...
资源来自pypi官网。 资源全名:django-redis-sentinel-plugin-1.0.0.tar.gz
redis 哨兵(sentinel)与springboot集成实战-redis-sentinel
redis-sentinel-demo redis-sentinel示例,实现高可用(Auto Failover:自动故障转移),主从自动切换.包含redis配置,redis-sentinel配置,以及Java示例代码. 参考原帖地址:...
redis-sentinel 组建脚本
docker-compose安装redis-sentinel集群(1主+2副+2哨兵)
Redis-Sentinel高可用架构学习
redis-sentinel介绍.rar
redis-5.0.14/src/redis-cli --cluster create 192.168.129.98:7000 192.168.129.99:7003 192.168.129.99:7002 192.168.129.126:7005 192.168.129.126:7004 192.168.129.98:7001 --cluster-replicas
搭建Redis高可用集群的哨兵模式(Redis-Sentinel)的实例配置,可以为 Redis 容灾+高可用 应用场景提供解决方案Demo
Redis在CentOS系统中创建集群可能会用到的安装包, 其中redis-3.0.0.tar是Redis服务, redis-3.0.0.gem是Redis通过ruby创建集群要用到的包
redis-sentinel哨兵集群搭建并整合springboot完美解决方案