成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一文說清楚配置數據源的參數

開發 前端
假如鏈接池中的鏈接被數據庫關閉了,應用經過鏈接池getConnection時,均可能獲取到這些不可用的鏈接,且這些鏈接若是不被其余線程回收的話;它們不會被鏈接池廢除,也不會從新被建立,占用了鏈接池的名額,項目若是是服務端,數據庫連接被關閉,客戶端調用服務端就會出現大量的timeout,客戶端設置了超時時間,會主動斷開,服務端就會出現close_wait。

鑒于在開發環境中,我們都使用過yml配置文件,而且我們在yml配置文件中,都加入過連接數據庫的配置,也就是配置我們的連接池,但是對于不同的數據庫,連接數據庫的 Jar 包也都是不一樣的,而且對應的配置也是不一樣的,今天阿粉就來說說這個 SpringBoot 項目中的,配置數據庫連接的各種參數以及不同的數據庫,應該是如何配置的。

MySQL的配置

我們先來看配置,然后我們再看看各項配置是什么意思。

spring:

datasource:

name: test

url: jdbc:mysql://localhost:3306/test

username: root

password: xxx

# 使用druid數據源

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.jdbc.Driver

filters: stat

maxActive: 20

initialSize: 1

maxWait: 60000

minIdle: 1

timeBetweenEvictionRunsMillis: 60000

minEvictableIdleTimeMillis: 300000

validationQuery: select 'x'

testWhileIdle: true

testOnBorrow: false

testOnReturn: false

poolPreparedStatements: true

上面最簡單的 name,url,username,password,type 這些阿粉也就不多說了,阿粉需要說的是剩下的參數都是代表的什么含義。

filters

這里配置的是插件,常用的插件有:

監控統計: filter:stat

日志監控: filter:log4j 或者 slf4j

防御SQL注入: filter:wall

maxActive

連接池中最多支持多少個活動會話

initialSize

啟動程序時,在連接池中初始化多少個連接

maxWait

程序向連接池中請求連接時,超過maxWait的值后,認為本次請求失敗,即連接池沒有可用連接,單位毫秒,設置-1時表示無限等待

minIdle

回收空閑連接時,將保證至少有minIdle個連接.

timeBetweenEvictionRunsMillis

檢查空閑連接的頻率,單位毫秒, 非正整數時表示不進行檢查

minEvictableIdleTimeMillis

池中某個連接的空閑時長達到 N 毫秒后, 連接池在下次檢查空閑連接時,將回收該連接,要小于防火墻超時設置net.netfilter.nf_conntrack_tcp_timeout_established的設置

validationQuery

檢查池中的連接是否仍可用的 SQL 語句,drui會連接到數據庫執行該SQL, 如果正常返回,則表示連接可用,否則表示連接不可用

testWhileIdle

當程序請求連接,連接池在分配連接時,是否先檢查該連接是否有效。(高效)

testOnBorrow

程序申請連接時,進行連接有效性檢查(低效,影響性能)

一般的話,設置均為false

testOnReturn

程序返還連接時,進行連接有效性檢查(低效,影響性能)

一般的話,設置均為false

poolPreparedStatements

緩存通過以下兩個方法發起的SQL:

public PreparedStatement prepareStatement(String sql)

public PreparedStatement prepareStatement(String sql,int resultSetType, int resultSetConcurrency)

推薦設置為true

其實有些配置,我們是非常熟悉的,為什么這么說,因為經常會有那種連接被關閉的錯誤,而這個錯誤則是有可能是參數配置不合適導致的。

配置可能引發的一些問題

其實我們比較需要注意的就是 validationQuery?這個參數,validationQuery是用來驗證數據庫連接的查詢語句,這個查詢語句必須是至少返回一條數據的SELECT語句。每種數據庫都有各自的驗證語句,阿粉也收集了幾種常見數據庫的validationQuery。

  • hsqldb select 1 from INFORMATION_SCHEMA.SYSTEM_USERS
  • Oracle select 1 from dual
  • DB2 select 1 from sysibm.sysdummy1
  • MySql select 1
  • Microsoft SqlServer select1
  • postgresql select version()
  • ingres select 1
  • derby values 1
  • H2 select 1

而這個參數,一般是否執行,都是靠著 testOnBorrow? 還有 testOnReturn

testOnBorrow設置為true后如果要生效,validationQuery參數必須設置為非空字符串。

同樣的 testOnReturn 設置為true后如果要生效,validationQuery參數必須設置為非空字符串。

但是如果我們設置 testOnBorrow 為 false 的時候,也會出現一些些的問題,

假如鏈接池中的鏈接被數據庫關閉了,應用經過鏈接池getConnection時,均可能獲取到這些不可用的鏈接,且這些鏈接若是不被其余線程回收的話;它們不會被鏈接池廢除,也不會從新被建立,占用了鏈接池的名額,項目若是是服務端,數據庫連接被關閉,客戶端調用服務端就會出現大量的timeout,客戶端設置了超時時間,會主動斷開,服務端就會出現close_wait。

這也是為什么有時候在排查日志的時候,會出現一些 close_wait 的錯誤,雖然知道并不影響業務,但是日志上看著還是難受。

那么為什么還要設置成 false 呢?

因為 testOnBorrow? 能夠確保我們每次都能獲取到可用的連接,但如果設置成 true ,則每次獲取連接的時候都要到數據庫驗證連接有效性,這在高并發的時候會造成性能下降,可以將testOnBorrow設成false,testWhileIdle設置成true這樣能獲得比較好的性能。

這樣也會執行我們上面所說的 validationQuery 參數中的 SQL 來驗證連接的有效性。

這樣在每次連接失效之后,都會通過validationQuery 來進行驗證是否失效。

責任編輯:武曉燕 來源: Java極客技術
相關推薦

2021-07-31 23:14:26

OpenCL框架語言

2025-02-19 10:49:24

2021-12-15 09:32:41

Linux系統負載

2023-03-28 07:51:56

CPU主板平臺

2020-05-11 07:57:33

區塊鏈分布式鏈上

2020-04-15 16:34:48

大數據質量標準

2024-09-23 05:10:00

微服務CORSSpringBoot

2021-02-11 08:08:09

Spring Boot配置架構

2020-03-02 15:17:37

云原生CNCF容器

2019-07-04 09:13:04

中臺百度團隊

2021-02-25 08:21:38

高可用風險故障

2025-02-05 09:17:40

2022-07-21 21:19:48

元宇宙

2018-11-28 11:08:30

并查集集合數據結構

2019-12-06 09:16:23

Linux 開源操作系統

2020-10-29 10:35:53

Nginx架構服務器

2021-01-27 08:12:04

Dotnet函數數據

2021-09-15 06:55:34

異步LinqC#

2025-05-23 10:00:00

網絡交換機STP

2025-05-28 02:00:00

AI智能體文本
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美成人aaa级毛片在线视频 | 欧美精品一区二区三区在线四季 | 久久久久久亚洲精品 | 91免费版在线观看 | 91国产在线播放 | 亚洲国产专区 | 精品欧美一区二区久久久伦 | 无码一区二区三区视频 | 日韩一级免费观看 | 色久影院 | 蜜桃精品视频在线 | 国产91精品久久久久久久网曝门 | 成人av片在线观看 | 成人av一区| 久久精品中文字幕 | 视频在线一区 | 欧美精品在线免费 | 中文在线a在线 | 日本中文字幕在线视频 | 一级爱爱片| 成人免费一区二区三区视频网站 | 在线亚洲电影 | 欧美一区二区免费电影 | 国产毛片av | 成人在线看片 | 久久一区二区三区四区五区 | 蜜臀网站 | 国产成人免费观看 | 九九九视频 | 中文字幕av亚洲精品一部二部 | 久草网站 | 国产黄色大片 | 在线日韩精品视频 | 一级大片网站 | 精品国产乱码久久久久久老虎 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 国产精品爱久久久久久久 | 久久精品一区 | 免费黄色a级毛片 | 久久久久久成人 | 久草视频2 |