Woj*_*arz 5 spring mongodb reactive-programming project-reactor
问题介于 Project Reactor 和 Reactive MongoDB (Spring Data) 之间。
执行包含(按以下顺序)的流时:
流被取消(查看下面的代码和日志)
@GetMapping("/test/{msg}")
public Mono<SomeObject> test(@PathVariable String msg) {
return repository.findByMessage(msg).log("1")
.map(someObj -> delaySeconds(someObj, 35)).log("2");
}
Run Code Online (Sandbox Code Playgroud)
如您所见,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))
Run Code Online (Sandbox Code Playgroud)
你能解释一下为什么流被取消了,我该如何处理?
是否有任何应该增加的超时,或者我是否以错误的方式使用 Project Reactor Stream API 和 MongoDB?
这是我的MongoDB配置
@Bean
public ReactiveMongoTemplate reactiveMongoTemplate() {
ConnectionString str = new ConnectionString(env.getMongoUri());
return new ReactiveMongoTemplate(MongoClients.create(str), str.getDatabase());
}
Run Code Online (Sandbox Code Playgroud)
任何的想法?如果您有类似的问题,请为这个问题点赞。
解决这个问题的方法很简单,但不是那么优雅:
@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");
}
Run Code Online (Sandbox Code Playgroud)
小智 3
我有一个类似的问题,反应式操作链花费了超过 30 秒的时间。就我而言,这是 Spring MVC 请求超时,解决方案如下:
Spring Boot 管理日志中重复出现 AsyncRequestTimeoutException
默认值为spring.mvc.async.request-timeout30 秒。
我相信这会有所帮助:)。
干杯!
| 归档时间: |
|
| 查看次数: |
727 次 |
| 最近记录: |