- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 kotlin 协程与“旧式”Spring JPA 存储库结合使用。我创建了一个新的协程范围并在“异步”中运行所有 JPA 调用。我发现即使使用非响应式 JDBC,我也可以提高吞吐量。
但我想知道,Spring JPA 存储库中可能存在一些协程包装器吗?用反射和 Spring“魔法”创造的东西?
最佳答案
首先我想澄清一件事以防止可能的混淆:如果你正在使用 Spring Data JPA,那么你应该知道这个框架使用 JDBC 驱动底层,这实际上是一个阻塞 API,这意味着所有的数据库调用都会使调用线程阻塞,直到总结果完成并准备好被消费.有了这些知识,我假设您正在使用 suspend
与在 Dispatcher.IO
上运行的协同程序一起运行进行此类调用。该调度程序为每次调用提供一个线程(据我所知,它最多可扩展到 64 个线程)。该线程实际上在进行数据库调用时阻塞,这意味着协同程序和 suspend
除了将阻塞调用切换到另一个线程(最终将被阻塞)之外,在这种情况下不会产生任何魔力。
也许你应该看看 r2dbc(响应式(Reactive) SQL 驱动程序)并使用 CoroutineCrudRepository<T, ID>
来自 Spring Data 而不是使用标准 JpaRepostitory<T, ID>
.
CoroutineCrudRepository<T, ID>
具有 suspend
的所有方法这意味着您可以使用它们来创建“真正的”异步 API,而不会完全阻塞。
但是,r2dbc 可能不适合您的用例,因为它有很多限制,例如映射关系、缓存等。
关于spring - Kotlin 协程与 Spring JPA 阻塞存储库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74731793/
在我的设置中,我试图有一个界面 Table继承自 Map (因为它主要用作 map 的包装器)。两个类继承自 Table - 本地和全局。全局的将有一个可变的映射,而本地的将有一个只有本地条目的映射。
Rust Nomicon 有 an entire section on variance除了关于 Box 的这一小节,我或多或少地理解了这一点和 Vec在 T 上(共同)变体. Box and Vec
我是一名优秀的程序员,十分优秀!