【问题标题】:Inserting Into Two Collections Without Blocking插入两个集合而不阻塞
【发布时间】:2019-07-31 06:03:38
【问题描述】:

我目前正在学习使用 Spring-WebFlux 的 Project Reactor。

我创建了一个简单的服务,它将按顺序插入到两个集合中。首先,我的服务将插入到列表集合中,然后将插入到详细信息集合中。如果两个操作都成功,它将返回第一个操作的实例(插入到列表集合中),如果其中一个不成功,它将回滚之前的操作创建的所有更改。

这是我的sn-p:

    override fun insert(business: Business): Mono<Business> = businessRepository.save(business)
    .doOnSuccess { businezz ->
        val businessDetails = businezz.businessDetails
        businessDetails!!.idBusiness = businezz.id
        businessDetailsService.insert(businessDetails).doOnError {
            businessRepository.delete(businezz).subscribe()
        }.subscribe()
    }

我觉得这是一种创建 Mono 的肮脏方式。由于第二个操作是块操作。当然,我可以只做一个插入列表然后插入详细信息然后获取列表。但是,这实际上会调用数据库 3 次,而不是像我上面的代码那样调用 2 次。

有什么方法可以让我创建一个非阻塞操作并且只调用 DB 2 次?

谢谢。

【问题讨论】:

  • 嗨,大卫,我删除了 Java 标记,因为您的问题仅使用 Kotlin。
  • 谢谢@LppEdd,我想既然Kotlin只是Java的扩展,添加java标签就可以了。下次我会小心的。

标签: spring-boot kotlin spring-data-mongodb spring-webflux


【解决方案1】:

我不熟悉 Kotlin,但使用 Java 你可以这样做:

Mono<Business> insert(Business business) {
    return businessRepository.save(business)
            .flatMap(businezz -> {
                BusinessDetails businessDetails = ...;
                return businessDetailsService.insert(businessDetails)
                        .onErrorResume(throwable -> businessRepository
                                .delete(businezz)
                                .then(Mono.empty()))
                        .then(Mono.just(businezz));
            });
}

科特林回答,谢谢大卫:

override fun insert(business: Business): Mono<Business> {
    return businessRepository.save(business).flatMap { businezz ->
        val businessDetails = businezz.businessDetails
        businessDetailsService.insert(businessDetails!!).onErrorResume { 
            businessRepository.delete(businezz).then(Mono.empty())
        }.then(Mono.just(businezz))
    }        
}

【讨论】:

  • 谢谢@Alexander Pankin。你给我一个主意。最后一个问题,为什么使用 flatMap 而不是 map?因为,我确实使用 Mono 而不是 Flux
  • 在反应器中flatMap 不会将 Flux“扁平化”为 Mono。当需要将“下一个”值传递给其他异步发布者时,我们将它与 Mono 或 Flux 一起使用。我们使用map,将“下一个”值传递给同步函数。
  • 谢谢你的解释!!
猜你喜欢
  • 2021-03-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-09-28
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多