其实是很久之前就更新了,混个脸熟。 新版本主要是稳定了基础功能,另外增加了一个实验性的手动定义切面无需注解的功能。 @Configuration public class DynamicConfiguration { @Bean public DynamicDataSourceConfigure dynamicDataSourceConfigure() { return DynamicDataSourceConfigure.config() .regexMatchers("com.baomidou.samples.nest.service.impl.*select.*", "mysql") .regexMatchers("com.baomidou.samples.nest.service.impl.*find.*", "oracle") .expressionMatchers("execution(* com.baomidou.samples.nest.service.impl.*.select*(..))", "mysql"); } } dynamic-datasource-spring-boot-starter 是一个基于springboot的快速集成多数据源的启动器。 文档非常完善,源码清晰易读,欢迎大家关注star。 简单使用直接访问 https://gitee.com/baomidou/dynamic-datasource-spring-boot-starter Druid集成(带全局参数加密),Hikaricp集成(带全局参数),MybatisPlus集成,P6SY集成,自定义数据源,动态增减数据源,spel解析数据源等等更多更细致的文档https://gitee.com/baomidou/dynamic-datasource-spring-boot-starter/wikis/pages 优势网上关于动态数据源的切换的文档有很多,核心只有两种。
如果你的数据源较少,场景不复杂,选择以上任意一种都可以。如果你需要更多特性,请尝试本动态数据源。
劣势不能使用多数据源事物(同一个数据源下能使用事物),网上其他方案也都不能提供。 如果你需要使用到分布式事物,那么你的架构应该到了微服务化的时候了。 PS: 如果您只是几个数据库但是有强烈的需求分布式事物,建议还是使用传统方式自己构建多套环境集成atomic这类,网上百度很多。 |