欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題-創(chuàng)新互聯(lián)

問題

最近某項目上出現(xiàn)一個奇怪的問題,就是數(shù)據(jù)庫經(jīng)常隔幾小時就報連接已關閉

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,義烏企業(yè)網(wǎng)站建設,義烏品牌網(wǎng)站建設,網(wǎng)站定制,義烏網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,義烏網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

即使是加了如下配置也依然不行,網(wǎng)上也沒找到什么文章解釋這個坑

test-on-borrow:?true
test-while-idle:?true
validation-query:?select?1?from?dual

排查

網(wǎng)上查不到,那就只能自己推敲猜測了。因為是mybatis多數(shù)據(jù)源的配置,所以每個db我都有專門寫一個config作為連接配置。

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

看著DataSourceConfig的代碼,我突然想到,會不會是因為我使用到是DataSource默認創(chuàng)建方法,所以并沒有讀取到我寫在application.yml的配置:

?@Bean(name?=?"db1DataSource")
?@ConfigurationProperties(prefix?=?"spring.datasource.db1")
?@Primary
?public?DataSource?dbDataSource()?{
?return?DataSourceBuilder.create().build();
?}

果斷跟進build()方法

	public?DataSource?build()?{
		Class<??extends?DataSource>?type?=?getType();
		DataSource?result?=?BeanUtils.instantiate(type);
		maybeGetDriverClassName();
		bind(result);
		return?result;
	}

打個斷點可以看到此時返回的result的是一個全新的DataSource

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

所以我們可以通過修改dbDataSource()方法,寫入我們的配置參數(shù):

?@Value("${spring.datasource.db1.url}")
?private?String?url;
?@Value("${spring.datasource.db1.username}")
?private?String?username;
?@Value("${spring.datasource.db1.password}")
?private?String?password;
?@Value("${spring.datasource.db1.tomcat.test-on-borrow}")
?private?boolean?testOnBorrow;
?@Value("${spring.datasource.db1.tomcat.test-while-idle}")
?private?boolean?testWhileIdle;
?@Value("${spring.datasource.db1.tomcat.validation-query}")
?private?String?validationQuery;
?@Value("${spring.datasource.db1.tomcat.max-idle}")
?private?int?maxIdle;
?@Value("${spring.datasource.db1.tomcat.min-idle}")
?private?int?minIdle;
?@Value("${spring.datasource.db1.tomcat.initial-size}")
?private?int?initialSize;
?@Value("${spring.datasource.db1.tomcat.max-active}")
?private?int?maxActive;
?@Value("${spring.datasource.db1.tomcat.time-between-eviction-runs-millis}")
?private?int?timeBetweenEvictionRunsMillis;
?@Bean(name?=?"db1DataSource")
?@ConfigurationProperties(prefix?=?"spring.datasource.db1")
?@Primary
?public?DataSource?dbDataSource()?{
?org.apache.tomcat.jdbc.pool.DataSource?dataSource?=?new?org.apache.tomcat.jdbc.pool.DataSource();
?dataSource.setDriverClassName("oracle.jdbc.driver.OracleDriver");
?dataSource.setUrl(url);
?dataSource.setUsername(username);
?dataSource.setPassword(password);
?dataSource.setMaxActive(maxActive);
?dataSource.setMinIdle(minIdle);
?dataSource.setMaxIdle(maxIdle);
?dataSource.setTestOnBorrow(testOnBorrow);
?dataSource.setTestWhileIdle(testWhileIdle);
?dataSource.setValidationQuery(validationQuery);
?dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
?dataSource.setInitialSize(initialSize);
?return?dataSource;
?//return?DataSourceBuilder.create().build();
?}

二次排查

通過上面方法確實可以解決問題了,但是我突然想到,默認創(chuàng)建的DataSource是沒有url,username,password等必要的基礎信息的。那這幾個配置參數(shù)是為什么又可以寫入進去呢?

這個時候我看到了我們dbDataSource方法上有一個@Bean(name = "db1DataSource"),于是大膽猜測我們這些配置參數(shù)的注入是第一次創(chuàng)建的時候通過Spring的IOC注入的。通過我的Debug發(fā)現(xiàn)事實也確實如此。

對DataBinder類的bind方法打斷點,

	public?void?bind(PropertyValues?pvs)?{
		MutablePropertyValues?mpvs?=?(pvs?instanceof?MutablePropertyValues)??
				(MutablePropertyValues)?pvs?:?new?MutablePropertyValues(pvs);
		doBind(mpvs);
	}

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

我們可以看到方法的調(diào)用路徑

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

看到了我們熟悉的refresh大法,這一部分Spring源碼相關請看Spring源碼分析

此時只剩最后一個疑惑了,我們的url,username,password等既然能通過IOC注入到DataSource里,那為什么其他的參數(shù)不可以呢?我隨著DataSource類一路往上,找到他的父類接口PoolConfiguration,看到了所有的參數(shù)和getset方法。

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

再看一眼我的application.yml配置文件里的參數(shù)

spring:
?datasource:
?db1:
?url:?
?username:?
?password:?
?driver-class-name:?oracle.jdbc.driver.OracleDriver
?tomcat:
?max-wait:?10000
?max-active:?30
?test-on-borrow:?true
?max-idle:?5
?db2:
?xxx
?....

終于找到這個坑了!

原來Spring data默認使用tomcat-jdbc的連接池的時候,配置的參數(shù)是

spring:
?datasource:
?url:?
?username:?
?password:?
?driver-class-name:?oracle.jdbc.driver.OracleDriver
?tomcat:
?max-wait:?10000
?max-active:?30
?test-on-borrow:?true
?max-idle:?5

而當使用多數(shù)據(jù)源配置的時候,簡單的以為只是復制過去即可,所以Spring IOC注入的時候,讀的到的tomcat.max-wait并不能匹配到DataSource里的setMaxWait方法。自然就不起作用了。

所以這個問題只需要將配置文件改為如下即可

spring:
?datasource:
?db1:
?url:?
?username:?
?password:?
?driver-class-name:?oracle.jdbc.driver.OracleDriver
?max-wait:?10000
?max-active:?30
?test-on-borrow:?true
?test-while-idle:?true
?validation-query:?select?1?from?dual
?max-idle:?5
?db2:
?xxx
?....

總結

這個問題從結果上來看,那真是簡單的不行,但是從過程上來說,不僅讓我又復習了一遍spring IOC的流程,也讓我感覺到這種一步一步解剖問題,把多個知識點連接起來的成就感。如果之前沒有學習spring的源碼,我這次大概率也不會想到去看bean的注入吧

點擊獲取?附送學習進階架構資料、PDF書籍文檔、面試資料

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

文章名稱:mybatis多數(shù)據(jù)源踩坑,數(shù)據(jù)庫連接經(jīng)常斷開問題-創(chuàng)新互聯(lián)
網(wǎng)站鏈接:http://chinadenli.net/article2/cejjic.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、手機網(wǎng)站建設網(wǎng)站制作、網(wǎng)站改版、標簽優(yōu)化、面包屑導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
日韩一区二区三区高清在| 国产日韩欧美在线播放| 日韩欧美一区二区黄色| 丰满少妇被猛烈插入在线观看| 一区二区三区四区亚洲专区| 国产又色又爽又黄又免费| 亚洲成人精品免费在线观看| 日本一区不卡在线观看| 99久久国产亚洲综合精品| 亚洲最大福利在线观看| 午夜精品一区二区三区国产| 久久亚洲国产视频三级黄| 亚洲国产性生活高潮免费视频| 91日韩欧美中文字幕| 久久午夜福利精品日韩| 日韩少妇人妻中文字幕| 午夜久久精品福利视频| 在线观看免费午夜福利| 日本深夜福利在线播放| 黄色日韩欧美在线观看| 内射精子视频欧美一区二区| 91久久精品在这里色伊人| 人妻精品一区二区三区视频免精| 丝袜美女诱惑在线观看| 久久福利视频视频一区二区 | 欧美做爰猛烈叫床大尺度| 国产精品午夜性色视频| 欧美午夜视频免费观看| 国产一级内片内射免费看| 午夜视频在线观看日韩| 亚洲中文字幕剧情在线播放| 老司机精品线观看86| 在线免费观看一二区视频| 中国日韩一级黄色大片| 成人亚洲国产精品一区不卡| 亚洲中文字幕乱码亚洲| 麻豆欧美精品国产综合久久| 高中女厕偷拍一区二区三区| 99久久精品午夜一区二区| 亚洲欧美日韩精品永久| 在线免费观看一二区视频|