首页 > 解决方案 > rsocket 使用 RSocket-Java 为 Spring Rsocket Server 路由元数据

问题描述

如何设置路由元数据(在服务器使用 Spring Boot Rsocket 时仅使用 RSocket-Java 在有效负载中。

Flux<Payload> s = connection.flatMapMany(requester -> requester.requestStream(DefaultPayload.create("Some Message")))

服务器正在使用 @MessageMapping("/route")

标签: spring-bootrsocketspring-rsocket

解决方案


交互类型

SpringBoot 上使用的 RSocket 交互类型@MessageMapping是根据注释方法的签名决定的(spring docs中的更多信息)

假设它有签名:

@MessageMapping("/route")
Flux<String> getStreamOfStrings(String message) {...}

基于spring docs交互类型的基数表是Request-Stream。

RSocket 客户端

RSocket java 客户端需要为元数据指定 mime-type:

RSocket rsocketClient = RSocketConnector.create()
    //metadata header needs to be specified
    .metadataMimeType(WellKnownMimeType.MESSAGE_RSOCKET_COMPOSITE_METADATA.getString())
    // value of spring.rsocket.server.port eg 7000
    .connect(TcpClientTransport.create(7000))
    .block();

数据

数据将是简单的字符串:

ByteBuf data = ByteBufAllocator.DEFAULT.buffer().writeBytes("request msg".getBytes());

元数据

RSocket中的路由被定义为元数据扩展,需要与数据一起发送来指定路由。这是如何创建它的示例(请参阅包io.rsocket.metadata中的其他类)

CompositeByteBuf metadata = ByteBufAllocator.DEFAULT.compositeBuffer();
RoutingMetadata routingMetadata = TaggingMetadataCodec.createRoutingMetadata(ByteBufAllocator.DEFAULT, List.of("/route"));
CompositeMetadataCodec.encodeAndAddMetadata(metadata,
        ByteBufAllocator.DEFAULT,
        WellKnownMimeType.MESSAGE_RSOCKET_ROUTING,
        routingMetadata.getContent());

请求流请求

创建数据和元数据,以便您可以requestSteam使用以下命令执行:

rsocketClient.requestStream(DefaultPayload.create(data, metadata))
    .map(Payload::getDataUtf8)
    .toIterable()
    .forEach(System.out::println);

推荐阅读