refactor(Druid - DataSource): 系统表与业务表分库读写 | 支持动态数据源切换
+ 使用AbstractRoutingDataSource实现动态数据源 + 数据库 sys 与 业务表划分为两部分独立数据库以实现多数据分区 + 添加过滤器在请求时识别请求类型通过determineCurrentLookupKey决定最终数据源 + ContextHolder 存储数据源标识确保全局统一 + 修改了FeedList模块的缓存初始化时机确保在第一次请求时初始化而非构造时
This commit is contained in:
24
zhyc-admin/src/main/java/com/zhyc/Event/FarmLoginEvent.java
Normal file
24
zhyc-admin/src/main/java/com/zhyc/Event/FarmLoginEvent.java
Normal file
@@ -0,0 +1,24 @@
|
||||
package com.zhyc.Event;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class FarmLoginEvent {
|
||||
|
||||
private final String farmCode;
|
||||
private final Long userId;
|
||||
|
||||
public FarmLoginEvent(String farmCode, Long userId) {
|
||||
this.farmCode = farmCode;
|
||||
this.userId = userId;
|
||||
}
|
||||
|
||||
public String getFarmCode() {
|
||||
return farmCode;
|
||||
}
|
||||
|
||||
public Long getUserId() {
|
||||
return userId;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
package com.zhyc.Routing.Filter;
|
||||
|
||||
import com.zhyc.framework.config.routing.DataSourceKeys;
|
||||
import com.zhyc.framework.datasource.DynamicDataSourceContextHolder;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.core.annotation.Order;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.web.filter.OncePerRequestFilter;
|
||||
|
||||
import javax.servlet.FilterChain;
|
||||
import javax.servlet.ServletException;
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import java.io.IOException;
|
||||
|
||||
@Component
|
||||
@Slf4j
|
||||
@Order(value = -100)
|
||||
public class DataSourceRoutingFilter extends OncePerRequestFilter {
|
||||
|
||||
@Override
|
||||
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
|
||||
|
||||
String uri = request.getRequestURI();
|
||||
|
||||
try {
|
||||
if (uri.startsWith("/app") || uri.startsWith("/base") || uri.startsWith("/biosafety") || uri.startsWith("/common")
|
||||
|| uri.startsWith("/dairyProducts") || uri.startsWith("/enums") || uri.startsWith("/feed") || uri.startsWith("/frozen") || uri.startsWith("/produce")
|
||||
|| uri.startsWith("sale") || uri.startsWith("/stock") || uri.startsWith("/work") || uri.startsWith("/sheepfold_management")) {
|
||||
log.debug("业务请求 : BUSINESS : {}", uri);
|
||||
DynamicDataSourceContextHolder.setDataSourceType(DataSourceKeys.FARM_1);
|
||||
} else {
|
||||
log.debug("系统请求 : SYSTEM : {}", uri);
|
||||
DynamicDataSourceContextHolder.setDataSourceType(DataSourceKeys.SYSTEM);
|
||||
}
|
||||
|
||||
filterChain.doFilter(request, response);
|
||||
} finally {
|
||||
// 业务结束后清楚数据源-防止线程复用导致错误
|
||||
DynamicDataSourceContextHolder.clearDataSourceType();
|
||||
}
|
||||
}
|
||||
}
|
||||
17
zhyc-admin/src/main/java/com/zhyc/web/mvc/MvcConfig.java
Normal file
17
zhyc-admin/src/main/java/com/zhyc/web/mvc/MvcConfig.java
Normal file
@@ -0,0 +1,17 @@
|
||||
package com.zhyc.web.mvc;
|
||||
|
||||
import com.zhyc.Routing.Filter.DataSourceRoutingFilter;
|
||||
import org.springframework.boot.web.servlet.FilterRegistrationBean;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
@Configuration
|
||||
public class MvcConfig {
|
||||
@Bean
|
||||
public FilterRegistrationBean<DataSourceRoutingFilter> myFilter() {
|
||||
FilterRegistrationBean<DataSourceRoutingFilter> registrationBean = new FilterRegistrationBean<>();
|
||||
registrationBean.setFilter(new DataSourceRoutingFilter());
|
||||
registrationBean.addUrlPatterns("/*");
|
||||
return registrationBean;
|
||||
}
|
||||
}
|
||||
@@ -9,16 +9,15 @@ spring:
|
||||
# url: jdbc:mysql://localhost:3306/zhyc?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
|
||||
# username: root
|
||||
# password: 123456
|
||||
url: jdbc:mysql://118.182.97.76:3306/zhyc?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
|
||||
url: jdbc:mysql://118.182.97.76:3306/zhyc_sys?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
|
||||
username: zhyc
|
||||
password: yszh123
|
||||
# 从库数据源
|
||||
slave:
|
||||
farm01:
|
||||
# 从数据源开关/默认关闭
|
||||
enabled: false
|
||||
url:
|
||||
username:
|
||||
password:
|
||||
url: jdbc:mysql://118.182.97.76:3306/zhyc_sheep01?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
|
||||
username: zhyc
|
||||
password: yszh123
|
||||
# 初始连接数
|
||||
initialSize: 5
|
||||
# 最小连接池数量
|
||||
|
||||
Reference in New Issue
Block a user