本文介紹了具有動(dòng)態(tài)數(shù)據(jù)源的Spring Boot JPA多租戶(hù)的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!
問(wèn)題描述
我正在嘗試創(chuàng)建一個(gè)多租戶(hù)Web應(yīng)用程序,我找到了一個(gè)很好的教程here。這解釋了如何配置MVC以找到新的租戶(hù)(使用CurrentTenantIdentifierResolver
和一個(gè)擴(kuò)展HandlerInterceptorAdapter
的MultiTenancyInterceptor),如何為三個(gè)不同的租戶(hù)配置三個(gè)不同的數(shù)據(jù)源,以及如何通過(guò)擴(kuò)展AbstractDataSourceBasedMultiTenantConnectionProviderImpl
在運(yùn)行時(shí)為服務(wù)器提供正確的數(shù)據(jù)源
現(xiàn)在,這是一個(gè)很好的起點(diǎn),讓我了解在春季和休眠中多租戶(hù)是如何工作的,但我想更進(jìn)一步,我想讓它成為完全動(dòng)態(tài)的租戶(hù),也就是說(shuō),我不會(huì)假設(shè)應(yīng)用程序可以有多少租戶(hù)。
我是這么想的:
應(yīng)用程序配置為在引導(dǎo)時(shí)掃描路徑(不在類(lèi)路徑中,例如/usr/data/config),并在各種目錄(每個(gè)租戶(hù)一個(gè)目錄)下找到各種應(yīng)用程序?qū)傩晕募鐃enantA、tenantB、tenantC…
對(duì)于每個(gè)應(yīng)用程序.properties,Spring Boot將基于該文件(該文件將只有引導(dǎo)屬性spring.datource.url)創(chuàng)建一個(gè)數(shù)據(jù)源。請(qǐng)注意,使用Spring Boot的屬性會(huì)很好,因?yàn)樗鼮槲姨峁┝藦膯蝹€(gè)URL所需的所有信息,如JDBC類(lèi)等。
我將在HashMap中注冊(cè)每個(gè)數(shù)據(jù)源(如上一個(gè)鏈接所示)
之后,前面的鏈接中已經(jīng)描述了基本的多租戶(hù)結(jié)構(gòu):每次最終用戶(hù)向?yàn)g覽器發(fā)出請(qǐng)求時(shí),服務(wù)器都會(huì)詳細(xì)說(shuō)明租戶(hù)并返回正確的數(shù)據(jù)源,以查找要使用的數(shù)據(jù)庫(kù)。
任何人都可以給我一些資源,如果這是以前做過(guò)的(我搜索了很多次,但沒(méi)有什么能讓我開(kāi)始),或者給出一些關(guān)于使用哪些Spring類(lèi)/配置來(lái)實(shí)現(xiàn)這一點(diǎn)的建議?
提前謝謝
推薦答案
如果有人有這種需要,我最終就是這么做的。
歡迎對(duì)此進(jìn)行任何進(jìn)一步擴(kuò)展,或?qū)η址缸罴褜?shí)踐的行為發(fā)表評(píng)論。
擴(kuò)展AbstractDataSourceBasedMultiTenantConnectionProviderImpl
的DataSourceProvider
必須重寫(xiě)兩個(gè)方法
selectAnyDataSource
,它返回一個(gè)@Autowired DataSource
,該@Autowired DataSource
是由Spring使用為應(yīng)用程序?qū)嵗瘮?shù)據(jù)源的常用方法實(shí)例化的。
selectDataSource(String tenant)
執(zhí)行以下操作:
獲取租戶(hù)的配置文件夾的路徑
實(shí)例化DataSourceProperties
,其屬性取自租戶(hù)的配置文件夾中的應(yīng)用程序.properties文件
通過(guò)DataSourceBuilder
創(chuàng)建并返回一個(gè)新的數(shù)據(jù)源,將先前實(shí)例化的DataSourceProperties中的字段用作屬性(這很有用,因?yàn)镾pring從數(shù)據(jù)庫(kù)URL動(dòng)態(tài)提供驅(qū)動(dòng)程序類(lèi)名)
此處提供的代碼,請(qǐng)隨意使用:
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();
這篇關(guān)于具有動(dòng)態(tài)數(shù)據(jù)源的Spring Boot JPA多租戶(hù)的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,