本文介紹了具有動態數據源的Spring Boot JPA多租戶的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在嘗試創建一個多租戶Web應用程序,我找到了一個很好的教程here。這解釋了如何配置MVC以找到新的租戶(使用CurrentTenantIdentifierResolver
和一個擴展HandlerInterceptorAdapter
的MultiTenancyInterceptor),如何為三個不同的租戶配置三個不同的數據源,以及如何通過擴展AbstractDataSourceBasedMultiTenantConnectionProviderImpl
在運行時為服務器提供正確的數據源
現在,這是一個很好的起點,讓我了解在春季和休眠中多租戶是如何工作的,但我想更進一步,我想讓它成為完全動態的租戶,也就是說,我不會假設應用程序可以有多少租戶。
我是這么想的:
應用程序配置為在引導時掃描路徑(不在類路徑中,例如/usr/data/config),并在各種目錄(每個租戶一個目錄)下找到各種應用程序屬性文件,例如tenantA、tenantB、tenantC…
對于每個應用程序.properties,Spring Boot將基于該文件(該文件將只有引導屬性spring.datource.url)創建一個數據源。請注意,使用Spring Boot的屬性會很好,因為它為我提供了從單個URL所需的所有信息,如JDBC類等。
我將在HashMap中注冊每個數據源(如上一個鏈接所示)
之后,前面的鏈接中已經描述了基本的多租戶結構:每次最終用戶向瀏覽器發出請求時,服務器都會詳細說明租戶并返回正確的數據源,以查找要使用的數據庫。
任何人都可以給我一些資源,如果這是以前做過的(我搜索了很多次,但沒有什么能讓我開始),或者給出一些關于使用哪些Spring類/配置來實現這一點的建議?
提前謝謝
推薦答案
如果有人有這種需要,我最終就是這么做的。
歡迎對此進行任何進一步擴展,或對侵犯最佳實踐的行為發表評論。
擴展AbstractDataSourceBasedMultiTenantConnectionProviderImpl
的DataSourceProvider
必須重寫兩個方法
selectAnyDataSource
,它返回一個@Autowired DataSource
,該@Autowired DataSource
是由Spring使用為應用程序實例化數據源的常用方法實例化的。
selectDataSource(String tenant)
執行以下操作:
獲取租戶的配置文件夾的路徑
實例化DataSourceProperties
,其屬性取自租戶的配置文件夾中的應用程序.properties文件
通過DataSourceBuilder
創建并返回一個新的數據源,將先前實例化的DataSourceProperties中的字段用作屬性(這很有用,因為Spring從數據庫URL動態提供驅動程序類名)
此處提供的代碼,請隨意使用:
String configPath = [...]; // Instantiate your configuration path
File file = new File(realPath);
DataSourceProperties dsProp = new DataSourceProperties();
Properties properties = new Properties();
try {
properties.load(new FileInputStream(file));
} catch (IOException e) {
throw new TenantNotConfiguredException(tenant); // Custom exception
}
PropertiesConfigurationFactory<DataSourceProperties> pcf = new PropertiesConfigurationFactory<>(dsProp);
pcf.setTargetName(DataSourceProperties.PREFIX);
pcf.setProperties(properties);
try {
dsProp = pcf.getObject();
} catch (Exception e) {
e.printStackTrace();
}
return DataSourceBuilder.create()
.url(dsProp.getUrl())
.driverClassName(dsProp.getDriverClassName())
.username(dsProp.getUsername())
.password(dsProp.getPassword())
.build();
這篇關于具有動態數據源的Spring Boot JPA多租戶的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,