1

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

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

示例(类似这样):

应用程序属性

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;
}

UserRepository (这是特定数据源的 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)........
    }
}

提前感谢您的帮助。

4

1 回答 1

1

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

quarkus.datasource.additional1.db-kind=postgresql 

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

于 2021-06-24T08:10:06.477 回答