如何设置路由元数据(在服务器使用Spring Boot Rsocket时仅使用RSocket-Java有效负载。
Flux<Payload> s = connection.flatMapMany(requester -> requester.requestStream(DefaultPayload.create("Some Message")))
服务器正在使用@MessageMapping("/route")
发布于 2020-07-07 21:14:55
交互类型
使用@MessageMapping的SpringBoot上的RSocket交互类型是根据带注释的方法的签名决定的(更多信息请参见spring docs)
让我们假设它有签名:
@MessageMapping("/route")
Flux<String> getStreamOfStrings(String message) {...}基于spring文档中的基数表,交互类型为Request-Stream。
RSocket客户端
RSocket java客户端需要为元数据指定mime类型:
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中路由被定义为metadata extension,需要与数据一起发送以指定路由。下面是如何创建它的示例(参见package 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);https://stackoverflow.com/questions/62742430
复制相似问题