ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

spring – 使用Reactive MongoDB和取消操作的流程正在取消

2019-07-05 14:17:50  阅读:368  来源: 互联网

标签:reactive-programming spring mongodb project-reactor


问题出在Project Reactor和Reactive MongoDB(Spring Data)之间.

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

>对Reactive MongoDB进行操作的方法非常快
>超过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");
}

解决方法:

我有一个类似的问题,当反应性操作链超过魔法30秒.在我的情况下,它是Spring MVC请求超时,这是slution:

Recurring AsyncRequestTimeoutException in Spring Boot Admin log

spring.mvc.async.request-timeout的dafault值为30秒.

我相信它会有所帮助:).

干杯!

标签:reactive-programming,spring,mongodb,project-reactor
来源: https://codeday.me/bug/20190705/1388176.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有