弹簧靴 + 弹簧数据,多租户

是否可以将 Spring Boot 配置为使用 MultiTenantConnectionProvider,以便我的系统的每个客户端都连接到他们自己的专用数据库?

具体来说,我希望使用内置的休眠支持来多租户:

这是我所追求的那种配置的一个例子,但我不知道如何在Spring Boot设置中使用它:

我尝试将这些属性添加到:application.properties

spring.jpa.hibernate.multiTenancy=DATABASE
spring.jpa.hibernate.tenant_identifier_resolver=com.mystuff.MyCurrentTenantIdentifierResolver
spring.jpa.hibernate.multi_tenant_connection_provider=com.mystuff.MyMultiTenantConnectionProviderImplX

我也尝试过自己编码,并尝试从我的主要@Configuration豆中提供这些:CurrentTenantIdentifierResolverMultiTenantConnectionProvider

@Bean
public CurrentTenantIdentifierResolver currentTenantIdentifierResolver() {
    return new CurrentTenantIdentifierResolver() {
        public String resolveCurrentTenantIdentifier() {
            // this is never called ...
        }
        public boolean validateExistingCurrentSessions() {
            // this is never called ...
        }
    };
}

@Bean
public MultiTenantConnectionProvider multiTenantConnectionProvider() {
    return new AbstractMultiTenantConnectionProvider() {
        protected ConnectionProvider getAnyConnectionProvider() {
            // this is never called ...
        }
        protected ConnectionProvider selectConnectionProvider(String s) {
            // this is never called ...
        }
    };
}

这些似乎都没有任何影响,所以我的问题真的是如何获取spring-boot/spring-data来使用这些多租户类?

感谢您的帮助!


答案 1

任何未定义的 JPA/休眠属性都可以使用 中的属性进行设置。spring.jpa.propertiesapplication.properties

您链接到的示例具有 3 个多租户属性:

<prop key="hibernate.multiTenancy">SCHEMA</prop>
<prop key="hibernate.tenant_identifier_resolver">com.webapp.persistence.utility.CurrentTenantContextIdentifierResolver</prop>
<prop key="hibernate.multi_tenant_connection_provider">com.webapp.persistence.utility.MultiTenantContextConnectionProvider</prop>

转换为 Spring Boot 的将是文件中的以下属性。application.properties

spring.jpa.properties.hibernate.multiTenancy=SCHEMA
spring.jpa.properties.hibernate.tenant_identifier_resolver=com.mystuff.MyCurrentTenantIdentifierResolver
spring.jpa.properties.hibernate.multi_tenant_connection_provider=com.webapp.persistence.utility.MultiTenantContextConnectionProvider

对于您的情况(如您的问题中所述)。

spring.jpa.properties.hibernate.multiTenancy=DATABASE
spring.jpa.properties.hibernate.tenant_identifier_resolver=com.webapp.persistence.utility.CurrentTenantContextIdentifierResolver 
spring.jpa.properties.hibernate.multi_tenant_connection_provider=com.mystuff.MyMultiTenantConnectionProviderImplX

它不适用于Spring manged bean,因为休眠控制着这些实例的生命周期。

有关更多属性,请参阅 Spring Boot 参考指南


答案 2

推荐