欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot Druid配置過程圖解

 更新時間:2020年03月26日 09:31:39   作者:趙小胖0914  
這篇文章主要介紹了SpringBoot Druid配置過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

Druid是阿里開源的一個JDBC應(yīng)用組件, 其包括三部分:

  • DruidDriver: 代理Driver,能夠提供基于Filter-Chain模式的插件體系。
  • DruidDataSource: 高效可管理的數(shù)據(jù)庫連接池。
  • SQLParser: 實用的SQL語法分析

通過Druid連接池中間件, 我們可以實現(xiàn):

  • 可以監(jiān)控數(shù)據(jù)庫訪問性能,Druid內(nèi)置提供了一個功能強大的StatFilter插件,能夠詳細統(tǒng)計SQL的執(zhí)行性能,這對于線上分析數(shù)據(jù)庫訪問性能有幫助。
  • 替換傳統(tǒng)的DBCP和C3P0連接池中間件。Druid提供了一個高效、功能強大、可擴展性好的數(shù)據(jù)庫連接池。
  • 數(shù)據(jù)庫密碼加密。直接把數(shù)據(jù)庫密碼寫在配置文件中,容易導致安全問題。DruidDruiver和DruidDataSource都支持PasswordCallback。
  • SQL執(zhí)行日志,Druid提供了不同的LogFilter,能夠支持Common-Logging、Log4j和JdkLog,你可以按需要選擇相應(yīng)的LogFilter,監(jiān)控你應(yīng)用的數(shù)據(jù)庫訪問情況。
  • 擴展JDBC,如果你要對JDBC層有編程的需求,可以通過Druid提供的Filter-Chain機制,很方便編寫JDBC層的擴展插件。

配置代碼如下

spring:
 datasource:
  type: com.alibaba.druid.pool.DruidDataSource
  driverClassName: com.mysql.cj.jdbc.Driver
  url: jdbc:mysql://${url}:${port}/${數(shù)據(jù)庫名}?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false&allowMultiQueries=true&useAffectedRows=true
  username: ${username}
  password: ${password}
 druid:
   initial-size: 10 # 初始化時建立物理連接的個數(shù)。初始化發(fā)生在顯示調(diào)用init方法,或者第一次getConnection時
   min-idle: 10 # 最小連接池數(shù)量
   maxActive: 200 # 最大連接池數(shù)量
   maxWait: 60000 # 獲取連接時最大等待時間,單位毫秒。配置了maxWait之后,缺省啟用公平鎖,并發(fā)效率會有所下降,如果需要可以通過配置
   timeBetweenEvictionRunsMillis: 60000 # 關(guān)閉空閑連接的檢測時間間隔.Destroy線程會檢測連接的間隔時間,如果連接空閑時間大于等于minEvictableIdleTimeMillis則關(guān)閉物理連接。
   minEvictableIdleTimeMillis: 300000 # 連接的最小生存時間.連接保持空閑而不被驅(qū)逐的最小時間
   validationQuery: SELECT 1 FROM DUAL # 驗證數(shù)據(jù)庫服務(wù)可用性的sql.用來檢測連接是否有效的sql 因數(shù)據(jù)庫方言而差, 例如 oracle 應(yīng)該寫成 SELECT 1 FROM DUAL
   testWhileIdle: true # 申請連接時檢測空閑時間,根據(jù)空閑時間再檢測連接是否有效.建議配置為true,不影響性能,并且保證安全性。申請連接的時候檢測,如果空閑時間大于timeBetweenEvictionRun
   testOnBorrow: false # 申請連接時直接檢測連接是否有效.申請連接時執(zhí)行validationQuery檢測連接是否有效,做了這個配置會降低性能。
   testOnReturn: false # 歸還連接時檢測連接是否有效.歸還連接時執(zhí)行validationQuery檢測連接是否有效,做了這個配置會降低性能。
   poolPreparedStatements: true # 開啟PSCache
   maxPoolPreparedStatementPerConnectionSize: 20 #設(shè)置PSCache值
   connectionErrorRetryAttempts: 3 # 連接出錯后再嘗試連接三次
   breakAfterAcquireFailure: true # 數(shù)據(jù)庫服務(wù)宕機自動重連機制
   timeBetweenConnectErrorMillis: 300000 # 連接出錯后重試時間間隔
   asyncInit: true # 異步初始化策略
   remove-abandoned: true # 是否自動回收超時連接
   remove-abandoned-timeout: 1800 # 超時時間(以秒數(shù)為單位)
   transaction-query-timeout: 6000 # 事務(wù)超時時間
   filters: stat,wall,log4j2
   connectionProperties: druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000
   web-stat-filter:
    enabled: true
    url-pattern: "/*"
    exclusions: "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*"
   stat-view-servlet:
    url-pattern: "/druid/*"
    allow:
    deny:
    reset-enable: false
    login-username: admin
    login-password: admin

druid監(jiān)控數(shù)據(jù)的外部化調(diào)用

@RestController
public class DruidStatController {
  @GetMapping("/stat")
  public Object druidStat() {
    // DruidStatManagerFacade#getDataSourceStatDataList 該方法可以獲取所有數(shù)據(jù)源的監(jiān)控數(shù)據(jù)
    return DruidStatManagerFacade.getInstance().getDataSourceStatDataList();
  }
}

圖例

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Springboot整合Jedis實現(xiàn)單機版或哨兵版可切換配置方法

    Springboot整合Jedis實現(xiàn)單機版或哨兵版可切換配置方法

    這篇文章主要介紹了Springboot整合Jedis實現(xiàn)單機版或哨兵版可切換配置方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-11-11
  • Java 使用反射調(diào)用jar包中的類方式

    Java 使用反射調(diào)用jar包中的類方式

    這篇文章主要介紹了Java 使用反射調(diào)用jar包中的類方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • redis實現(xiàn)多進程數(shù)據(jù)同步工具代碼分享

    redis實現(xiàn)多進程數(shù)據(jù)同步工具代碼分享

    這篇文章主要介紹了使用redis實現(xiàn)多進程數(shù)據(jù)同步工具的代碼,大家參考使用吧
    2014-01-01
  • java?Map接口子類HashMap遍歷與LinkedHashMap詳解

    java?Map接口子類HashMap遍歷與LinkedHashMap詳解

    這篇文章主要介紹了java?Map接口子類HashMap遍歷與LinkedHashMap詳解,Map接口下的集合與Collection接口下的集合,它們存儲數(shù)據(jù)的形式不同,感興趣的小伙伴可以參考下面文章詳細內(nèi)容介紹
    2022-06-06
  • springboot之Jpa通用接口及公共方法使用示例

    springboot之Jpa通用接口及公共方法使用示例

    這篇文章主要為大家介紹了springboot?之Jpa通用接口及公共方法使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • logback-spring.xml的內(nèi)容格式詳解

    logback-spring.xml的內(nèi)容格式詳解

    這篇文章主要介紹了logback-spring.xml的內(nèi)容格式詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的的朋友參考下吧
    2023-11-11
  • 使用RestTemplate調(diào)用RESTful?API的代碼示例

    使用RestTemplate調(diào)用RESTful?API的代碼示例

    在開發(fā)?Web?應(yīng)用程序時,調(diào)用?RESTful?API?是一個常見的任務(wù),本文將介紹如何使用?RestTemplate?調(diào)用?RESTful?API,并提供示例代碼,感興趣的同學可以跟著小編一起來看看
    2023-06-06
  • Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解

    Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解

    這篇文章主要介紹了Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解,動態(tài)代理是一種在運行時動態(tài)生成代理對象的技術(shù),它是一種設(shè)計模式,用于在不修改原始對象的情況下,通過代理對象來間接訪問原始對象,并在訪問前后執(zhí)行額外的操作,需要的朋友可以參考下
    2024-01-01
  • java實現(xiàn)撲克牌分發(fā)功能

    java實現(xiàn)撲克牌分發(fā)功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)撲克牌分發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 單一職責原則_動力節(jié)點Java學院整理

    單一職責原則_動力節(jié)點Java學院整理

    這篇文章主要為大家詳細介紹了單一職責原則的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08

最新評論