Redis 低成本、高可用设计,花费近一年时间整理的Java核心知识清单

本文主要介绍下使用官方sentinel做redis高可用方案的设计。

Redis Sentinel


Sentinel介绍

Sentinel是Redis官方为集群提供的高可用解决方案。在实际项目中可以使用sentinel去做redis自动故障转移,减少人工介入的工作量。

另外sentinel也给客户端提供了监控消息的通知,这样客户端就可根据消息类型去判断服务器的状态,去做对应的适配操作。

下面是Sentinel主要功能列表:

  • Monitoring:Sentinel持续检查集群中的master、slave状态,判断是否存活。

  • Notification:在发现某个redis实例死的情况下,Sentinel能通过API通知系统管理员或其他程序脚本。

  • Automatic failover:如果一个master挂掉后,sentinel立马启动故障转移,把某个slave提升为master。其他的slave重新配置指向新master。

  • Configuration provider:对于客户端来说sentinel通知是有效可信赖的。客户端会连接sentinel去请求当前master的地址,一旦发生故障sentinel会提供新地址给客户端。

Sentinel配置

Sentinel本质上只是一个运行在特殊模式下的redis服务器,通过不同配置来区分提供服务。

sentinel.conf配置:


// [监控名称] [ip] [port] [多少sentinel同意才发生故障转移]

sentinel monitor mymaster 127.0.0.1 6379 2

// [监控名称] [Master多少毫秒后不回应ping命令,就认为master是主观下线状态]

sentinel down-after-milliseconds mymaster 60000

// [故障转移超时时间]

sentinel failover-timeout mymaster 180000

//[在执行故障转移时,最多可以有多少个从服务器同时对新的主服务器进行同步]

sentinel parallel-syncs mymaster 1 

sentinel需要使用redis2.8版本以上,启动如下:


redis-sentinel sentinel.conf 

启动后Sentinel会:

  • 以10秒一次的频率,向被监视的master发送info命令,根据回复获取master当前信息。

  • 以1秒一次的频率,向所有redis服务器、包含sentinel在内发送PING命令,通过回复判断服务器是否在线。

  • 以2秒一次的频率,通过向所有被监视的master,slave服务器发送包含当前sentinel,master信息的消息。

    另外建议sentinel至少起3个实例以上,并配置2个实例同意即可发生转移。5个实例,配置3个实例同意以此类推。

故障转移消息接收的3种方式


Redis服务器一旦发送故障后,sentinel通过raft算法投票选举新master。故障转移过程可以通过sentinel的API获取/订阅接收事件消息。Redis 系列面试题和答案我都整理完了,关注公众号Java技术栈回复:面试,可以免费获取哦。

脚本接收


//当故障转移期间,可以指定一个“通知”脚本用来告知系统管理员,当前集群的情况。

//脚本被允许执行的最大时间为60秒,如果超时,脚本将会被终止(KILL)


sentinel notification-script mymaster /var/redis/notify.sh 

//故障转移期之后,配置通知客户端的脚本.


sentinel client-reconfig-script mymaster /var/redis/notifyReconfig.sh 

客户端直接接收


Sentinel的故障转移消息通知使用的是redis发布订阅,就是说在故障转移期间所有产生的事件信息,都通过频道(channel)发布出去。

比如我们加台slave服务器,sentinel监听到后会发布加slave的消息到"+slave"频道上,客户端只需要订阅"+slave"频道即可接收到对应消息。

其消息格式如下:[实例类型] [事件服务器名称] [服务器ip] [服务器端口] @[master名称] [ip] [端口]


<instance-type> <name> <ip> <port> @ <master-name> <master-ip> <master-port> 

通知消息格式示例:


*          //订阅类型, *即订阅所有事件消息。

-sdown     //消息类型

slave 127.0.0.1:6379 127.0.0.1 6379 @ mymaster 127.0.0.1 6381 

订阅消息示例:


using (RedisSentinel rs = new RedisSentinel(CurrentNode.Host, CurrentNode.Port))

{


# 总结

如果你选择了IT行业并坚定的走下去,这个方向肯定是没有一丝问题的,这是个高薪行业,但是高薪是凭自己的努力学习获取来的,这次我把P8大佬用过的一些学习笔记(pdf)都整理在本文中了,如果你有需要的话,请一定**点赞分享本文**

**[CodeChina开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.csdn.net/m0_60958482/java-p7)**

**《Java中高级核心知识全面解析》**

![](https://img-blog.csdnimg.cn/img_convert/d7ad292b656a721579600eadc17f66b9.png)

**小米商场项目实战,别再担心面试没有实战项目:**



**[CodeChina开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频】](https://codechina.csdn.net/m0_60958482/java-p7)**

**《Java中高级核心知识全面解析》**

[外链图片转存中...(img-S4uhqJtl-1630838424806)]

**小米商场项目实战,别再担心面试没有实战项目:**

![](https://img-blog.csdnimg.cn/img_convert/ce5f65759882b907654d6d54eecc91da.png)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值