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

Spring Boot 整合 Druid 并開啟監(jiān)控的操作方法

 更新時間:2025年01月24日 10:17:28   作者:binbinxyz  
本文介紹了如何在SpringBoot項目中引入和配置Druid數(shù)據(jù)庫連接池,并開啟其監(jiān)控功能,通過添加依賴、配置數(shù)據(jù)源、開啟監(jiān)控、自定義配置以及訪問監(jiān)控頁面,開發(fā)者可以有效提高數(shù)據(jù)庫訪問效率并監(jiān)控連接池狀態(tài),感興趣的朋友跟隨小編一起看看吧

1. 引言

隨著互聯(lián)網(wǎng)應用的快速發(fā)展,對數(shù)據(jù)庫連接池的要求也越來越高。傳統(tǒng)的連接池可能無法滿足現(xiàn)代應用對于高性能和高可用性的需求。而 Druid 憑借其優(yōu)秀的性能優(yōu)化、詳細的監(jiān)控數(shù)據(jù)以及靈活的配置選項,成為了許多開發(fā)者的首選。接下來,我們將一步步展示如何在 Spring Boot 中引入 Druid,并啟用它的監(jiān)控功能。

2. 添加依賴

首先,在你的 pom.xml 文件中添加 Druid 的 Maven 依賴:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-3-starter</artifactId>
    <version>1.2.24</version>
</dependency>

如果你使用的是 Gradle 構建工具,則可以在 build.gradle 文件中添加如下內(nèi)容:

implementation 'com.alibaba:druid-spring-boot-3-starter:1.2.24'

3. 配置數(shù)據(jù)源

接下來,在 application.properties 或 application.yml 文件中配置 Druid 數(shù)據(jù)源的相關參數(shù)。這里以 .properties 文件為例:

# Druid 數(shù)據(jù)源配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20
spring.datasource.druid.test-on-borrow=true
spring.datasource.druid.validation-query=SELECT 1 FROM DUAL
# 監(jiān)控頁面設置
spring.datasource.druid.web-stat-filter.enabled=true
spring.datasource.druid.stat-view-servlet.enabled=true
spring.datasource.druid.stat-view-servlet.login-username=druid
spring.datasource.druid.stat-view-servlet.login-password=d1234

yaml示例:

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=false
    username: root
    password: 1234
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      test-on-borrow: true
      validation-query: SELECT 1 FROM DUAL
      web-stat-filter:
        enabled: true
      stat-view-servlet:
        enabled: true
        login-username: druid
        login-password: d1234

上述配置項包括了連接池的基本參數(shù)(如初始大小、最小空閑連接數(shù)、最大活動連接數(shù)等),同時也啟用了 Druid 的 Web 統(tǒng)計過濾器和統(tǒng)計視圖 Servlet,并設置了登錄用戶名和密碼用于訪問監(jiān)控頁面。

4. 開啟監(jiān)控功能

為了更好地管理和監(jiān)控 Druid 連接池的工作狀態(tài),我們需要開啟 Druid 提供的監(jiān)控功能。這可以通過配置文件中的幾個關鍵屬性來實現(xiàn):

  • WebStatFilter:用于收集 Web 應用程序的 SQL 慢查詢?nèi)罩尽?/li>
  • StatViewServlet:提供了一個可視化的監(jiān)控頁面,可以查看連接池的各項指標。

確保在 application.properties 或 application.yml 中啟用了這兩個組件:

# 啟用 WebStatFilter 和 StatViewServlet
spring.datasource.druid.web-stat-filter.enabled=true
spring.datasource.druid.stat-view-servlet.enabled=true

此外,還可以進一步自定義監(jiān)控頁面的安全策略,比如允許或限制特定 IP 地址訪問、設置更多的登錄憑證等。

5. 自定義 Druid 配置(可選)

如果默認配置不能滿足你的需求,你可以創(chuàng)建一個自定義的 Druid 配置類來覆蓋默認設置。例如:

@Configuration
public class DruidConfig {
    @ConfigurationProperties(prefix = "spring.datasource.druid")
    @Bean
    public DruidDataSource druidDataSource() {
        return new DruidDataSource();
    }
    // 如果需要,可以在這里添加更多配置,如過濾器、攔截器等
    @Bean
    public ServletRegistrationBean<StatViewServlet> statViewServlet() {
        ServletRegistrationBean<StatViewServlet> bean = new ServletRegistrationBean<>(new StatViewServlet(), "/druid/*");
        Map<String, String> params = new HashMap<>();
        params.put("loginUsername", username);
        params.put("loginPassword", password);
        params.put("allow", "localhost");
        params.put("deny", "");
        bean.setInitParameters(params);
        return bean;
    }
    @Bean
    public FilterRegistrationBean<Filter> webStatFilter() {
        FilterRegistrationBean<Filter> bean = new FilterRegistrationBean<Filter>();
        bean.setFilter(new WebStatFilter());
        Map<String, String> params = new HashMap<>();
        params.put("exclusions", "*.js,*.css,/druid/*");
        bean.setUrlPatterns(Arrays.asList("/*"));
        bean.setInitParameters(params);
        return bean;
    }
}

6. 訪問監(jiān)控頁面

完成上述配置后,啟動 Spring Boot 應用程序,然后打開瀏覽器并訪問以下 URL 來查看 Druid 的監(jiān)控頁面:

http://localhost:8080/druid/

使用之前設置的用戶名和密碼登錄后,你將看到一個包含詳細連接池信息和 SQL 查詢統(tǒng)計的界面。通過這個頁面,你可以輕松地監(jiān)控數(shù)據(jù)庫連接的狀態(tài)、分析 SQL 性能瓶頸等問題。

7. 注意事項

  • 生產(chǎn)環(huán)境安全:在生產(chǎn)環(huán)境中部署時,請務必加強對監(jiān)控頁面的訪問控制,避免敏感信息泄露。
  • 性能影響:雖然 Druid 的監(jiān)控功能非常有用,但在高并發(fā)場景下可能會對系統(tǒng)性能產(chǎn)生一定影響。因此,在實際應用中應權衡利弊,合理配置監(jiān)控級別。
  • 更新維護:定期檢查 Druid 版本更新,及時修復已知漏洞和問題,保持系統(tǒng)的穩(wěn)定性和安全性。

8. 總結(jié)

通過以上步驟,我們成功地在 Spring Boot 應用中集成了 Druid 數(shù)據(jù)庫連接池,并開啟了其監(jiān)控功能。這不僅提高了數(shù)據(jù)庫訪問的效率,還為開發(fā)者提供了寶貴的調(diào)試和優(yōu)化工具。希望這篇文章能夠幫助你。

更多配置或使用請參考官方文檔:https://github.com/alibaba/druid

到此這篇關于Spring Boot 整合 Druid 并開啟監(jiān)控的文章就介紹到這了,更多相關Spring Boot Druid 開啟監(jiān)控內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 關于java.lang.IncompatibleClassChangeError錯誤解決方案

    關于java.lang.IncompatibleClassChangeError錯誤解決方案

    最近開發(fā)中遇到類沖突報錯 java.lang.IncompatibleClassChangeError,所以下面這篇文章主要給大家介紹了關于java.lang.IncompatibleClassChangeError錯誤的解決方案,需要的朋友可以參考下
    2024-02-02
  • Java實現(xiàn)帶附件的郵件發(fā)送功能

    Java實現(xiàn)帶附件的郵件發(fā)送功能

    這篇文章主要為大家詳細介紹了Java實現(xiàn)帶附件的郵件發(fā)送功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Java使用GUI實現(xiàn)貪吃蛇游戲詳解

    Java使用GUI實現(xiàn)貪吃蛇游戲詳解

    小時候經(jīng)常在諾基亞上玩的一個小游戲-貪吃蛇,你還記得嗎?本篇帶你重溫一下把它實現(xiàn),做的比較簡單,但還是可以玩的.感興趣的朋友快來看看吧
    2022-05-05
  • 全面了解Java反射機制

    全面了解Java反射機制

    Java的反射機制在實踐中可謂無處不在,如果你已經(jīng)工作幾年,還對Java的反射機制一知半解,那么這篇文章絕對值得你讀一讀。
    2020-03-03
  • SpringBoot 如何根據(jù)不同profile選擇不同配置

    SpringBoot 如何根據(jù)不同profile選擇不同配置

    這篇文章主要介紹了SpringBoot 如何根據(jù)不同profile選擇不同配置的操作方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • 詳解Spring與Mybatis整合方法(基于IDEA中的Maven整合)

    詳解Spring與Mybatis整合方法(基于IDEA中的Maven整合)

    這篇文章主要介紹了Spring與Mybatis整合方法(基于IDEA中的Maven整合),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • mybatis-plus返回查詢總記錄數(shù)方式

    mybatis-plus返回查詢總記錄數(shù)方式

    這篇文章主要介紹了mybatis-plus返回查詢總記錄數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • java中enum的用法

    java中enum的用法

    這篇文章主要介紹了java中enum的用法,包括了枚舉類型的基本定義及用法分析,對于學習Java有著一定的學習與借鑒價值,需要的朋友可以參考下
    2014-11-11
  • Java中的SynchronousQueue阻塞隊列使用代碼實例

    Java中的SynchronousQueue阻塞隊列使用代碼實例

    這篇文章主要介紹了Java中的SynchronousQueue阻塞隊列使用代碼實例,SynchronousQueue是無緩沖區(qū)的阻塞隊列,即不能直接向隊列中添加數(shù)據(jù),會報隊列滿異常,需要的朋友可以參考下
    2023-12-12
  • Java 并發(fā)編程之線程掛起、恢復與終止

    Java 并發(fā)編程之線程掛起、恢復與終止

    這篇文章主要介紹了Java 并發(fā)編程之線程掛起、恢復與終止的相關資料,需要的朋友可以參考下
    2017-05-05

最新評論