反应式 Quarkus:对多个数据源使用反应式 PanacheORM

问题描述

我正在尝试连接到两个不同的数据库(均使用反应式连接),但我无法为第二个数据库创建连接池并继续使用 Panache。

我尝试使用 Quarkus 文档中的 @ReactiveDataSource 注释,但我无法为某些实体设置此连接以通过 Panache 对该特定池执行操作。

示例(类似这样):

application.properties

quarkus.datasource.db-kind=postgresql 
quarkus.datasource.username=user-default
quarkus.datasource.password=password-default
quarkus.datasource.reactive.url=postgresql://localhost:5432/default

quarkus.datasource."additional1".db-kind=postgresql 
quarkus.datasource."additional1".username=user-additional1
quarkus.datasource."additional1".password=password-additional1
quarkus.datasource."additional1".reactive.url=postgresql://localhost:5432/additional1

用户实体

public class User extends PanacheEntity {
    private String name;
}

用户存储库 (这是特定数据源的 Panache 配置应该发生的地方!!)

@ApplicationScoped
public class UserRepository {
    @Inject
    @ReactiveDataSource("additional1")
    PgPool additional1Client;

    public Uni<User> findUserById(int id) {
          // set the _additional1Client_ pool in the Panache to make User.findById(id)........
    }
}

在此先感谢您的帮助。

解决方法

我正在检查指南,看看你做了什么。 但是当我使用名称源时,我没有使用“,所以尝试删除它们,然后可能会起作用。因此:

quarkus.datasource.additional1.db-kind=postgresql 

如本文所述: https://quarkus.io/guides/datasource#multiple-datasources

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...