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

[经验分享] redis-sentinel 做HA

[复制链接]

尚未签到

发表于 2015-11-12 11:29:51 | 显示全部楼层 |阅读模式
基本介绍
  本文基于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切换后应用配置的连接不可用的情况。
  

安装配置

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=&quot;font-size:24px;&quot;>sentinel.conf主要有6个配置项</span>
<span style=&quot;color:#ff0000;&quot;>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=&quot;color:#006600;&quot;>该行最后的数字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=&quot;color:#3333ff;&quot;>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=&quot;color:#3333ff;&quot;>191 变成role:master</span>

<span style=&quot;color:#3333ff;&quot;>重新开启 192
redis-cli info Replication 192 role:slave</span>
<span style=&quot;color:#3333ff;&quot;>再把191 shutdown 192 又变回master了</span>



Spring配置文件&代码

<bean id=&quot;sentinelConfiguration&quot; class=&quot;org.springframework.data.redis.connection.RedisSentinelConfiguration&quot;>
<property name=&quot;master&quot;>
<bean class=&quot;org.springframework.data.redis.connection.RedisNode&quot;>
<property name=&quot;name&quot; value=&quot;mymaster&quot;></property>
</bean>
</property>
<property name=&quot;sentinels&quot;>
<set>
<bean class=&quot;org.springframework.data.redis.connection.RedisNode&quot;>
<constructor-arg name=&quot;host&quot; value=&quot;192.168.14.192&quot;></constructor-arg>
<constructor-arg name=&quot;port&quot; value=&quot;26379&quot;></constructor-arg>
</bean>
<bean class=&quot;org.springframework.data.redis.connection.RedisNode&quot;>
<constructor-arg name=&quot;host&quot; value=&quot;192.168.14.191&quot;></constructor-arg>
<constructor-arg name=&quot;port&quot; value=&quot;26379&quot;></constructor-arg>
</bean>
</set>
</property>
</bean>
<bean id=&quot;connectionFactory&quot; class=&quot;org.springframework.data.redis.connection.jedis.JedisConnectionFactory&quot;>
<constructor-arg name=&quot;sentinelConfig&quot; ref=&quot;sentinelConfiguration&quot;></constructor-arg>
</bean>
<bean id=&quot;redisTemplate&quot; class=&quot;org.springframework.data.redis.core.StringRedisTemplate&quot;>
<property name=&quot;connectionFactory&quot; ref=&quot;connectionFactory&quot; />
</bean>



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

sentinelConfiguration配置监听的列表

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


redisTemplate:到connectionFactory获取连接



Long listFormRedis=redisTemplate.opsForList().size(&quot;login_record_list&quot;);
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



  

版权声明:本文为博主原创文章,未经博主允许不得转载。

运维网声明 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-138277-1-1.html 上篇帖子: 基于redis分布式缓存实现 下篇帖子: redis异常解决:jedis.exceptions.JedisDataException: ERR Client sent AUTH, but no pass
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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