竹笋

首页 » 问答 » 环境 » Spring官方RSocketBrok
TUhjnbcbe - 2022/3/11 14:35:00
北京那个治疗白癜风医院比较好 https://jbk.39.net/yiyuanfengcai/hj_bjzkbdfyy/
Spring官方的RSocketBroker其实开发已经非常久了,我以为会伴随着SpringCloud.0发布的,但是没有发生。不过SpringRSocketBroker还是发布了最新的0.版本,虽然还是预览版,但目前已经可用,考虑官方还没有提供对应的文档,大家入门做Demo还有些困难,所以这篇文章就是帮你快速入门SpringRSocketBroker,同时解析一下RSocketBroker的特性。一SpringRSocketBroker架构首先让我们看一下SpringRSocketBroker的架构图,如下:RSocketBroker为一个集群对外提供服务,其主要服务就是应用注册和RSocket请求的转发,集群中的每一个Broker都维护着统一的全局路由表。RSocketBroker有两个监听端口:端口主要负责提供对外RSocket服务,如应用到Broker之间的长连接,然后就是该长连接之上的RSocket请求的发送和接收。端口主要负责集群内部Broker节点之间的通讯,如同步应用接入的元数据信息,确保全局服务路由表的统一,还包括Broker之间的请求转发,当然Broker之间的通讯协议还是RSocket。当一个服务应用和Broker建立连接时,会将一些基础信息发送给Broker,对应的属性主要包括:路由节点ID(routeId)、服务名称(sevice-name),tags(标签)。路由节点ID(routeId):这个是应用到broker创建的长连接的唯一标识,通常是UUID,当然也可以用户自己指定,连接的唯一性会让各个Broker集群的全局路由表处理方便很多。注意routeId是长连接的标识,不是应用的标识,应用的标识是通过tags进行标识的。如果一个应用和broker创建两条长连接,那么就有两个不同的routeId,当然这种情况下每一条连接可以提供不同的服务名称。服务名称:这个其实就是服务的DNSName,如果其他应用想调用该应用提供的RSocket服务,就需要指定该服务名称。虽然SpringRSocket提供了messageMapping,但是mapping的key是应用内部的,并不能保证全局唯一,只有ServiceName+RSocketMappingKey才能定位指定的服务,这个和
1
查看完整版本: Spring官方RSocketBrok