我正在尝试连接到两个不同的数据库(都具有反应式连接),但我无法为第二个数据库创建连接池并继续使用 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)........
}
}
提前感谢您的帮助。