SpringBoot?@DS注解實現(xiàn)多數(shù)據(jù)源配置以及問題解決辦法
一、導(dǎo)入依賴:
<!--配置多數(shù)據(jù)源--> <dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>3.5.0</version> </dependency>
二、配置文件:
datasource: dynamic: druid: initial-size: 5 min-idle: 5 maxActive: 20 # 配置獲取連接等待超時的時間 maxWait: 60000 # 配置間隔多久才進行一次檢測,檢測需要關(guān)閉的空閑連接,單位是毫秒 timeBetweenEvictionRunsMillis: 6000 # 配置一個連接在池中最小生存的時間,單位是毫秒 minEvictableIdleTimeMillis: 60000 # 配置一個連接在池中最大生存的時間,單位是毫秒 maxEvictableIdleTimeMillis: 900000 validationQuery: SELECT 1 FROM DUAL testWhileIdle: true testOnBorrow: false testOnReturn: false # 打開PSCache,并且指定每個連接上PSCache的大小 poolPreparedStatements: true maxPoolPreparedStatementPerConnectionSize: 20 primary: master #設(shè)置默認的數(shù)據(jù)源或者數(shù)據(jù)源組,默認值即為master strict: false #嚴(yán)格匹配數(shù)據(jù)源,默認false. true未匹配到指定數(shù)據(jù)源時拋異常,false使用默認數(shù)據(jù)源 datasource: master: driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0開始支持SPI可省略此配置 url: jdbc:mysql://localhost:3306/table1?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true username: xxxx password: xxxxx slave_1: driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0開始支持SPI可省略此配置 url: jdbc:mysql://localhost:3306/table2?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true username: xxxx password: xxxxx
三、在啟動類上配置一行
@SpringBootApplication(exclude={DataSourceAutoConfiguration.class})
四、在需要切換數(shù)據(jù)源的類上、方法上使用@DS注解(一般是用在mapper、service)
五、@DS注解不生效的幾種情況
進過驗證,@DS注解加到mapper接口、service接口、service方法里都不生效,獲取的還是默認的主數(shù)據(jù)源。猜測是由于spring的aop切面機制導(dǎo)致攔截不到@DS注解,進而不能切換數(shù)據(jù)源,正確的做法是添加到service實現(xiàn)類或者實現(xiàn)類里具體的方法上。
在事務(wù)方法內(nèi)調(diào)用@DS注解的方法,@DS注解同樣不生效,原因是spring只能攔截到最外層方法的@Transactional注解,此時加載該事務(wù)的數(shù)據(jù)源,在事務(wù)方法內(nèi)即使調(diào)用了@DS注解的方法,獲取的是外層事務(wù)的數(shù)據(jù)源,導(dǎo)致@DS失效。
在同一個實現(xiàn)類中,一個非DS注解的常規(guī)方法里調(diào)用@DS注解的方法,同樣存在@DS失效的情況,原因同2,是由spring的aop機制導(dǎo)致的,如果確有這種業(yè)務(wù)需要,可以將該DS注解方法定義在不同的類中,通過bean注入的方式調(diào)用,就不會出現(xiàn)這個問題。
六、本人使用時遇到的問題:
配置文件配置的jackson時間返回格式失效了,返回的還是時間戳格式數(shù)據(jù)
原:(無效)
jackson: date-format: yyyy-MM-dd HH:mm:ss time-zone: GMT+8
可能原因:
添加攔截器并繼承 WebMvcConfigurationSupport 后會覆蓋@EnableAutoConfiguration關(guān)于WebMvcAutoConfiguration的配置!從而導(dǎo)致所有的Date返回都變成時間戳。
解決辦法:
在繼承了 WebMvcConfigurationSupport的攔截器中,重寫extendMessageConverters方法
public class xxxConfig extends WebMvcConfigurationSupport { @Override public void extendMessageConverters(List<HttpMessageConverter<?>> converters) { MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter(); ObjectMapper objectMapper = converter.getObjectMapper(); // 生成JSON時,將所有Long轉(zhuǎn)換成String SimpleModule simpleModule = new SimpleModule(); simpleModule.addSerializer(Long.class, ToStringSerializer.instance); simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance); objectMapper.registerModule(simpleModule); // 時間格式化 objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); objectMapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")); // 設(shè)置格式化內(nèi)容 converter.setObjectMapper(objectMapper); converters.add(0, converter); } }
注:需要導(dǎo)入的依賴
<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-typehandlers-jsr310</artifactId> <version>1.0.1</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.datatype</groupId> <artifactId>jackson-datatype-jsr310</artifactId> <version>2.9.2</version> </dependency>
啟動的時候找不到數(shù)據(jù)源,報"java.lang.ClassNotFoundException: com.mysql.cj.jdbc.Driver"異常
首先檢查是否引入了mysql-connector-java依賴:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.15</version> </dependency>
其次檢查jar包版本是否是6.x及以上(因為 com.mysql.cj.jdbc.Driver這個類就位于mysql-connector-java的6.x版本中)
總結(jié)
到此這篇關(guān)于SpringBoot @DS注解實現(xiàn)多數(shù)據(jù)源配置以及問題解決辦法的文章就介紹到這了,更多相關(guān)SpringBoot @DS注解多數(shù)據(jù)源配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解析springboot整合谷歌開源緩存框架Guava Cache原理
本文主要為大家解析了springboot整合谷歌開源緩存框架Guava Cache的原理以及在實際開發(fā)過程中的使用,附含源碼,有需要的朋友可以參考下2021-08-08Java中的Set、List、Map的用法與區(qū)別介紹
這篇文章主要介紹了Java中的Set、List、Map的用法與區(qū)別,需要的朋友可以參考下2016-06-06Springboot2.x+ShardingSphere實現(xiàn)分庫分表的示例代碼
這篇文章主要介紹了Springboot2.x+ShardingSphere實現(xiàn)分庫分表的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10基于String和List<String>間的相互轉(zhuǎn)換方式
這篇文章主要介紹了基于String和List間的相互轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05