sentinel源码分析第十四篇一核心流程一集群架构

配置图

  • 一个集群的节点包含配置的server以及client
  • 没有配置的节点不会纳入集群
  • 一个业务应用程序甚至可以配置多个集群限流
  • 当配置完毕后,控制面板会为所有client和server发送请求
  • client请求负责启动嵌入式client
  • server请求负责启动嵌入式sever
  • 还需为client设置server的ip信息
    在这里插入图片描述

架构图

在这里插入图片描述

Http架构

  • ClusterStateManager在类加载通过sentinel内部的InitFunc执行机制完成httpserver的启动
  • 用户可以发送http://:/setClusterMode?mode=
  • mode = 0 表示设置为client,mode = 1 表示设置为server

参见: sentinel github

在这里插入图片描述

  • 同时上述请求触发ClusterStateManager启动嵌入式服务端或者客户端
    在这里插入图片描述

客户端架构

  • 客户端通过DefaultClusterTokenClient发送请求
  • 通过TokenClientHandler接收请求
  • 通过 TokenClientPromiseHolder以及request-response id完成请求响应映射
    在这里插入图片描述

服务端结构

  • 服务端通过TokenServerHandler处理请求
  • 并根据requestType是流控还是热点获取对应的Processor
  • 通过processor调用DefaultTokenService处理集群限流逻辑
  • 设置response.id = resquest,id 并响应客户端
    在这里插入图片描述

总结

  • 集群模式必须前置配置完集群节点拓扑结构
  • 否则集群规则不生效会降级成单机限流或直接通过限流
  • 通过控制面板配置

扩展点一集群示例图

  • 6台机器都是一个applicationName应用下的不同instance
  • 我们可以配置两个集群
  • 则灰色的集群和蓝色的集群各自独立工作互不影响
    在这里插入图片描述
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值