网站首页 > java教程 正文
pom引入
SpringBoot版本使用的是2.1.7
<!-- Druid -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.16</version>
</dependency>
<!-- Mybatis Plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.1.0</version>
</dependency>
添加各种配置类
yml
spring:
datasource:
master:
# 连接数据库的url
url: jdbc:mysql://ip:3306/wbmp?useUnicode=true&characterEncoding=UTF-8&useSSL=false&autoReconnect=true&failOverReadOnly=false&serverTimezone=GMT%2B8
# 连接数据库的账号
username:
# 连接数据库的密码
password:
# 使用druid数据源
type: com.alibaba.druid.pool.DruidDataSource
esb:
# 连接数据库的url
url: jdbc:mysql://ip:3306/ssamgt?useUnicode=true&characterEncoding=UTF-8&useSSL=false&autoReconnect=true&failOverReadOnly=false&serverTimezone=GMT%2B8
# 连接数据库的账号
username:
# 连接数据库的密码
password:
# 使用druid数据源
type: com.alibaba.druid.pool.DruidDataSource
druid:
# 扩展插件
# 监控统计用的filter:stat 日志用的filter:log4j 防御sql注入的filter:wall
filters: stat
# 最大连接池数量
max-active: 20spring:
#其他更多项省略
java文件
MultipleDataSourceConfig
/**
* 多数据源bean的配置类
*
* @author zzy
*/
@Configuration
public class MultipleDataSourceConfig {
@Bean
@ConfigurationProperties(prefix = "spring.datasource.master")
public DataSource master() {
DataSource build = DruidDataSourceBuilder.create().build();
return build;
}
@Bean
@ConfigurationProperties(prefix = "spring.datasource.esb")
public DataSource esb() {
DataSource build = DruidDataSourceBuilder.create().build();
return build;
}
/**
* 设置动态数据源,通过@Primary 来确定主DataSource
*
* @return
*/
@Bean
@Primary
public DynamicDataSource dynamicDataSource() {
DynamicDataSource dynamicDataSource = new DynamicDataSource();
//设置默认数据源
dynamicDataSource.setDefaultTargetDataSource(master());
//配置多数据源
Map<Object, Object> map = new HashMap<>();
map.put(DynamicDataSourceSwitcher.Mater, master());
map.put(DynamicDataSourceSwitcher.Slave, esb());
dynamicDataSource.setTargetDataSources(map);
return dynamicDataSource;
}
}
DynamicDataSourceAspect
/**
* 创建aop切面
* @author zzy
*/
@Aspect
@Component
@Order(1)
@Slf4j
public class DynamicDataSourceAspect {
@Pointcut(value="@within(org.springframework.stereotype.Service) && @annotation(dataSource)" )
public void dynamicDataSourcePointCut(DataSource dataSource){}
@Before(value = "dynamicDataSourcePointCut(dataSource)")
public void switchDataSource(DataSource dataSource){
log.info("##############数据源 :{}###############",dataSource.value());
DynamicDataSourceSwitcher.setDataSource(dataSource.value());
}
@After(value="dynamicDataSourcePointCut(dataSource)")
public void after(DataSource dataSource){
DynamicDataSourceSwitcher.cleanDataSource();
}
}
题外话:
如果你是要访问同一个实例中的不同数据库,那么只要你登陆的用户具有这几个库的权限,是不用配置多数据源的,直接使用库名.表名写sql即可,当然你非要配置也是可以的,但是没有必要。
多数据源一般针对的是,分布在不同实例中的数据库进行访问。
教程就到这里了
enjoy it。
猜你喜欢
- 2024-10-13 深度分析ClassLoader机制,不可错过这一篇
- 2024-10-13 RxJava2.X 源码解析(一):探索RxJava2分发订阅流程
- 2024-10-13 与其他语言相比,Java有多安全?(java语言有哪些缺点)
- 2024-10-13 JVM 配置参数 -D,-X,-XX 的区别
- 2024-10-13 mysql-connector-java与MySQL 8.X版本建立连接
- 2024-10-13 浙江大学终于把java整理成漫画书了,动画教学更生动,允许白嫖
- 2024-10-13 java 核心技术-12版 卷Ⅰ- 4.1 面向对象程序设计概述
- 2024-10-13 JAVA 中获取比X大1位数中最小的数
- 2024-10-13 玩大了!Log4j 2.x 再爆雷(log4j最新版本)
- 2024-10-13 全面解读 Java 日志框架(一)(java主流日志框架)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)