具有反应式MongoDB的流和取消耗时的操作

时间:2018-07-31 11:52:18

标签: spring mongodb reactive-programming project-reactor

问题在Project Reactor和Reactive MongoDB(春季数据)之间。

在执行包含(按以下顺序)的流时:

  1. 反应式MongoDB 上运行的方法非常快速
  2. 方法耗时超过 30秒

流已被取消(请查看下面的代码和日志)

@GetMapping("/test/{msg}")
public Mono<SomeObject> test(@PathVariable String msg) {
    return repository.findByMessage(msg).log("1")
          .map(someObj -> delaySeconds(someObj, 35)).log("2");
}

如您所见,流被取消30秒后,但又过了5秒(超时为35秒),事件 onNext 被执行。

12:59:18.556 [Thread-9] INFO  com.why.temp.TempController - Saved:SomeObject(id=5b604106ef301746a86665f3, message=WHY)
12:59:18.591 [http-nio-8080-exec-2] INFO  1 - | onSubscribe([Fuseable] MonoFlatMap.FlatMapMain)
12:59:18.592 [http-nio-8080-exec-2] INFO  2 - | onSubscribe([Fuseable] FluxMapFuseable.MapFuseableSubscriber)
12:59:18.593 [http-nio-8080-exec-2] INFO  2 - | request(unbounded)
12:59:18.593 [http-nio-8080-exec-2] INFO  1 - | request(unbounded)
12:59:18.612 [Thread-8] INFO  1 - | onNext(SomeObject(id=5b604106ef301746a86665f3, message=WHY))
12:59:49.116 [http-nio-8080-exec-3] INFO  2 - | cancel()
12:59:49.117 [http-nio-8080-exec-3] INFO  1 - | cancel()
12:59:53.612 [Thread-8] INFO  2 - | onNext(SomeObject(id=5b604106ef301746a86665f3, message=WHY))

您能解释一下为什么取消流以及如何处理吗?

是否应该增加任何超时时间?或者我是否以错误的方式使用Project Reactor Stream API和MongoDB?

这是我的 MongoDB 配置

@Bean
public ReactiveMongoTemplate reactiveMongoTemplate() {
    ConnectionString str = new ConnectionString(env.getMongoUri());
    return new ReactiveMongoTemplate(MongoClients.create(str), str.getDatabase());
}

有什么主意吗?如果您有类似的问题,请对这个问题进行投票。

解决方法很简单,但并不那么优雅:

@GetMapping("/test/{msg}")
public Mono<SomeObject> test(@PathVariable String msg) {
    SomeObj someObj = repository.findByMessage(msg).block();
    return Mono.just(someObj).log("1")
        .map(someObj -> delaySeconds(someObj, 35)).log("2");
}

1 个答案:

答案 0 :(得分:1)

我有一个类似的问题,即反应式操作链耗时超过30秒。就我而言,这是Spring MVC请求超时,这是解决方案:

Recurring AsyncRequestTimeoutException in Spring Boot Admin log

spring.mvc.async.request-timeout的默认值是30秒。

我相信这会有所帮助:)。

干杯!