我有以下程序连接到在 localhost:7999 上运行的 Spring boot rsocket 服务器。我已经配置了连接器Retry.fixedDelay(Integer.MAX_VALUE, Duration.ofSeconds(5))
如您所见,RSocketRequester 是 Mono,因此它应该保持一个连接。当连接失败并且重试开始时,我看到每次重试都是从不同的线程进行的,即如下parallel-1
--- parallel-8
。我可以知道这背后的原因吗?
12:08:24.463550|parallel-1|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #1 (1 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:08:30.470593|parallel-2|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #2 (2 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:08:36.475666|parallel-3|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #3 (3 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:08:42.494801|parallel-4|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #4 (4 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:08:48.499084|parallel-5|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #5 (5 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:08:54.503385|parallel-6|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #6 (6 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:09:00.509830|parallel-7|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #7 (7 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:09:06.545815|parallel-8|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #8 (8 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
12:09:12.553582|parallel-1|WARN |RSocketRefDataReceiver |doAfterRetry===>attempt #9 (9 in a row), last failure={io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection refused: no further information: localhost/127.0.0.1:7999}
我的程序如下:
RSocketStrategies strategies = RSocketStrategies.builder()
.encoders(e -> e.add(new Jackson2CborEncoder()))
.decoders(e -> e.add(new Jackson2CborDecoder()))
.build();
Mono<RSocketRequester> requester = Mono.just(RSocketRequester.builder()
.rsocketConnector(connector -> {
connector.reconnect(
Retry.fixedDelay(Integer.MAX_VALUE, Duration.ofSeconds(5))
.doAfterRetry(e -> LOG.warn("doAfterRetry===>{}", e)))
.acceptor(RSocketMessageHandler.responder(strategies,this))
.payloadDecoder(PayloadDecoder.ZERO_COPY);
})
.dataMimeType(MediaType.APPLICATION_CBOR)
.setupRoute("test")
.setupData("test-123")
.rsocketStrategies(strategies)
.tcp("localhost",7999));