问题描述
我正在尝试连接到两个不同的数据库(均使用反应式连接),但我无法为第二个数据库创建连接池并继续使用 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