Spring Boot 整合 Druid 并開啟監(jiān)控的操作方法
1. 引言
隨著互聯(lián)網(wǎng)應(yīng)用的快速發(fā)展,對數(shù)據(jù)庫連接池的要求也越來越高。傳統(tǒng)的連接池可能無法滿足現(xiàn)代應(yīng)用對于高性能和高可用性的需求。而 Druid 憑借其優(yōu)秀的性能優(yōu)化、詳細(xì)的監(jiān)控?cái)?shù)據(jù)以及靈活的配置選項(xiàng),成為了許多開發(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 構(gòu)建工具,則可以在 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ù)源的相關(guān)參數(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)控頁面設(shè)置 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
上述配置項(xiàng)包括了連接池的基本參數(shù)(如初始大小、最小空閑連接數(shù)、最大活動(dòng)連接數(shù)等),同時(shí)也啟用了 Druid 的 Web 統(tǒng)計(jì)過濾器和統(tǒng)計(jì)視圖 Servlet,并設(shè)置了登錄用戶名和密碼用于訪問監(jiān)控頁面。
4. 開啟監(jiān)控功能
為了更好地管理和監(jiān)控 Druid 連接池的工作狀態(tài),我們需要開啟 Druid 提供的監(jiān)控功能。這可以通過配置文件中的幾個(gè)關(guān)鍵屬性來實(shí)現(xiàn):
- WebStatFilter:用于收集 Web 應(yīng)用程序的 SQL 慢查詢?nèi)罩尽?/li>
- StatViewServlet:提供了一個(gè)可視化的監(jiān)控頁面,可以查看連接池的各項(xiàng)指標(biāo)。
確保在 application.properties 或 application.yml 中啟用了這兩個(gè)組件:
# 啟用 WebStatFilter 和 StatViewServlet spring.datasource.druid.web-stat-filter.enabled=true spring.datasource.druid.stat-view-servlet.enabled=true
此外,還可以進(jìn)一步自定義監(jiān)控頁面的安全策略,比如允許或限制特定 IP 地址訪問、設(shè)置更多的登錄憑證等。
5. 自定義 Druid 配置(可選)
如果默認(rèn)配置不能滿足你的需求,你可以創(chuàng)建一個(gè)自定義的 Druid 配置類來覆蓋默認(rèn)設(shè)置。例如:
@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)控頁面
完成上述配置后,啟動(dòng) Spring Boot 應(yīng)用程序,然后打開瀏覽器并訪問以下 URL 來查看 Druid 的監(jiān)控頁面:
http://localhost:8080/druid/
使用之前設(shè)置的用戶名和密碼登錄后,你將看到一個(gè)包含詳細(xì)連接池信息和 SQL 查詢統(tǒng)計(jì)的界面。通過這個(gè)頁面,你可以輕松地監(jiān)控?cái)?shù)據(jù)庫連接的狀態(tài)、分析 SQL 性能瓶頸等問題。
7. 注意事項(xiàng)
- 生產(chǎn)環(huán)境安全:在生產(chǎn)環(huán)境中部署時(shí),請務(wù)必加強(qiáng)對監(jiān)控頁面的訪問控制,避免敏感信息泄露。
- 性能影響:雖然 Druid 的監(jiān)控功能非常有用,但在高并發(fā)場景下可能會對系統(tǒng)性能產(chǎn)生一定影響。因此,在實(shí)際應(yīng)用中應(yīng)權(quán)衡利弊,合理配置監(jiān)控級別。
- 更新維護(hù):定期檢查 Druid 版本更新,及時(shí)修復(fù)已知漏洞和問題,保持系統(tǒng)的穩(wěn)定性和安全性。
8. 總結(jié)
通過以上步驟,我們成功地在 Spring Boot 應(yīng)用中集成了 Druid 數(shù)據(jù)庫連接池,并開啟了其監(jiān)控功能。這不僅提高了數(shù)據(jù)庫訪問的效率,還為開發(fā)者提供了寶貴的調(diào)試和優(yōu)化工具。希望這篇文章能夠幫助你。
更多配置或使用請參考官方文檔:https://github.com/alibaba/druid
到此這篇關(guān)于Spring Boot 整合 Druid 并開啟監(jiān)控的文章就介紹到這了,更多相關(guān)Spring Boot Druid 開啟監(jiān)控內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot+Druid開啟監(jiān)控頁面的實(shí)現(xiàn)示例
- SpringBoot整合Druid實(shí)現(xiàn)SQL監(jiān)控和數(shù)據(jù)庫密碼加密
- SpringBoot整合mybatis使用Druid做連接池的方式
- SpringBoot整合Mybatis-Plus+Druid實(shí)現(xiàn)多數(shù)據(jù)源配置功能
- springboot 整合druid及配置依賴
- 解決springboot整合druid遇到的坑
- springboot 整合druid數(shù)據(jù)庫密碼加密功能的實(shí)現(xiàn)代碼
- SpringBoot整合Druid數(shù)據(jù)源過程詳解
- 詳解Spring Boot整合Mybatis實(shí)現(xiàn) Druid多數(shù)據(jù)源配置
相關(guān)文章
關(guān)于java.lang.IncompatibleClassChangeError錯(cuò)誤解決方案
最近開發(fā)中遇到類沖突報(bào)錯(cuò) java.lang.IncompatibleClassChangeError,所以下面這篇文章主要給大家介紹了關(guān)于java.lang.IncompatibleClassChangeError錯(cuò)誤的解決方案,需要的朋友可以參考下2024-02-02Java實(shí)現(xiàn)帶附件的郵件發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)帶附件的郵件發(fā)送功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08SpringBoot 如何根據(jù)不同profile選擇不同配置
這篇文章主要介紹了SpringBoot 如何根據(jù)不同profile選擇不同配置的操作方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08詳解Spring與Mybatis整合方法(基于IDEA中的Maven整合)
這篇文章主要介紹了Spring與Mybatis整合方法(基于IDEA中的Maven整合),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10Java中的SynchronousQueue阻塞隊(duì)列使用代碼實(shí)例
這篇文章主要介紹了Java中的SynchronousQueue阻塞隊(duì)列使用代碼實(shí)例,SynchronousQueue是無緩沖區(qū)的阻塞隊(duì)列,即不能直接向隊(duì)列中添加數(shù)據(jù),會報(bào)隊(duì)列滿異常,需要的朋友可以參考下2023-12-12