文章目录
- 配置图
 - 架构图
 
- Http架构
 - 客户端架构
 - 服务端结构
 
- 总结
 - 扩展点一集群示例图
 
配置图
- 一个集群的节点包含配置的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
 - 我们可以配置两个集群
 - 则灰色的集群和蓝色的集群各自独立工作互不影响
 

                










