SpringBoot集成Druid監(jiān)控頁面最小化配置操作
在項(xiàng)目中使用阿里的druid連接池,pom文件配置:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.1.14</version> </dependency>
application.properties配置,官方文檔可查:
# Druid連接池配置,官方配置參考:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter spring.datasource.url=jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.type=com.alibaba.druid.pool.DruidDataSource # Druid其他配置 spring.datasource.druid.initial-size=5 spring.datasource.druid.max-active=20 spring.datasource.druid.min-idle=10 spring.datasource.druid.max-wait=10 spring.datasource.druid.filters=stat,wall spring.datasource.druid.filter.stat.log-slow-sql=true spring.datasource.druid.filter.stat.slow-sql-millis=2000 # Druid WebStatFilter配置,說明請(qǐng)參考Druid Wiki,配置_配置WebStatFilter spring.datasource.druid.web-stat-filter.enabled=true spring.datasource.druid.web-stat-filter.url-pattern=/* spring.datasource.druid.web-stat-filter.exclusions=*.gif,*.png,*.jpg,*.html,*.js,*.css,*.ico,/druid/* # Druid StatViewServlet配置,說明請(qǐng)參考Druid Wiki,配置_StatViewServlet配置 spring.datasource.druid.stat-view-servlet.enabled=true spring.datasource.druid.stat-view-servlet.url-pattern=/druid/* spring.datasource.druid.stat-view-servlet.reset-enable=true spring.datasource.druid.stat-view-servlet.login-username=admin spring.datasource.druid.stat-view-servlet.login-password=admin spring.datasource.druid.stat-view-servlet.allow= spring.datasource.druid.stat-view-servlet.deny=
OK,搞定~
接下來,啟動(dòng)項(xiàng)目,打開地址:http://localhost:8080/druid
頁面長(zhǎng)這樣:

我來請(qǐng)求一下接口,查詢sql,確實(shí)監(jiān)控到了:

補(bǔ)充知識(shí):druid 配置理解及監(jiān)控界面參數(shù)理解
druid 配置理解
官方文檔中的很多配置,不是太理解或者貌似理解了,自己不實(shí)踐一下,心里也不踏實(shí),所以決定自己搞一個(gè)demo測(cè)試一下理解理解各個(gè)配置到底是什么意思
一、druidDataSource 配置
| 參數(shù)名稱 | 我的理解 | 官方說明 |
|---|---|---|
| pool-prepared-statements | preparedStatement的創(chuàng)建會(huì)消耗很多的系統(tǒng)資源,同樣的sql可以重用preparedStatement | 是否緩存preparedStatement,也就是PSCache。PSCache對(duì)支持游標(biāo)的數(shù)據(jù)庫性能提升巨大,比如說oracle。在mysql下建議關(guān)閉 |
| initial-size | 初始化連接數(shù) | 連接池建立時(shí)創(chuàng)建的初始化連接數(shù) |
| max-pool-prepared-statement-per-connection-size | 這個(gè)我不是太確定,這個(gè)應(yīng)該是PSCache的緩存大小吧,官方說可以給大一點(diǎn),單位也不清楚,那就給100吧 | … |
| validation-query | 這個(gè)配置還是很容易理解的,關(guān)鍵是怎么去驗(yàn)證一下,比如在testOnBorrow=true,當(dāng)申請(qǐng)鏈接時(shí),確實(shí)會(huì)執(zhí)行validation-query.我是這樣驗(yàn)證的,validation-query=select 1 from dualss(有語法錯(cuò)誤的sql),結(jié)果在申請(qǐng)鏈接的時(shí)候就報(bào)錯(cuò)了,證明在testOnBorrow的時(shí)候確實(shí)執(zhí)行了validation-query,后面的testOnReturn,testWhileIdle我沒有驗(yàn)證,應(yīng)該都一樣 | 用來檢測(cè)連接是否有效的sql,要求是一個(gè)查詢語句,常用select ‘x'。如果validationQuery為null,testOnBorrow、testOnReturn、testWhileIdle都不會(huì)起作用。 |
| validation-query-timeout | 不知道怎么驗(yàn)證 | … |
| test-on-borrow | 不知道怎么驗(yàn)證,因?yàn)闊o論是true,還是false,只要validation-query有值,都會(huì)執(zhí)行一下validation-query | |
| test-on-return | 不知道怎么驗(yàn)證 | |
| test-while-idle | 不知道怎么驗(yàn)證 | |
| time-between-eviction-runs-millis | 默認(rèn)是1分鐘,就是destory每隔1分鐘會(huì)執(zhí)行一次 |
二、后臺(tái)監(jiān)控頁面中的各數(shù)值的含義
我的端口是8585,就是如下圖這個(gè)界面中每行

| 參數(shù)名稱 | 中文 | 我的理解 | 官方說明 |
|---|---|---|---|
| ActiveCount | 活躍連接數(shù) | 有n個(gè)連接正在執(zhí)行sql,那么這個(gè)值就為n | 當(dāng)前連接池中活躍連接數(shù) |
| InitialSize | 初始化連接大小 | 默認(rèn)就是項(xiàng)目啟動(dòng)就會(huì)初始化的連接數(shù) | 連接池建立時(shí)創(chuàng)建的初始化連接數(shù) |
| LogicConnectCount | 邏輯連接打開次數(shù) | 與MaxActive沒有關(guān)系,連接被用一次,LogicConnectCount就會(huì)+1,就是連接池中的連接被用次數(shù)綜合 | 產(chǎn)生的邏輯連接建立總數(shù) |
| minEvictableIdleTimeMillis | 連接保持空閑而不被驅(qū)逐的最小時(shí)間 |
以上這篇SpringBoot集成Druid監(jiān)控頁面最小化配置操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- SpringBoot集成阿里巴巴Druid監(jiān)控的示例代碼
- 使用SpringBoot簡(jiǎn)單了解Druid的監(jiān)控系統(tǒng)的配置方法
- SpringBoot配置Druid數(shù)據(jù)監(jiān)控代碼實(shí)例
- SpringBoot對(duì)Druid配置SQL監(jiān)控功能失效問題及解決方法
- springboot項(xiàng)目中實(shí)現(xiàn)訪問druid內(nèi)置監(jiān)控頁面
- SpringBoot集成Druid連接池進(jìn)行SQL監(jiān)控的問題解析
- SpringBoot整合Druid實(shí)現(xiàn)數(shù)據(jù)庫連接池和監(jiān)控
- SpringBoot3整合Druid監(jiān)控功能的項(xiàng)目實(shí)踐
- SpringBoot集成Druid實(shí)現(xiàn)監(jiān)控功能的示例代碼
- springboot關(guān)閉druid監(jiān)控 druid2改配置文件無效的解決
- Springboot整合Druid實(shí)現(xiàn)對(duì)訪問的監(jiān)控方式
- SpringBoot+Druid開啟監(jiān)控頁面的實(shí)現(xiàn)示例
相關(guān)文章
解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題
這篇文章主要介紹了解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10
談?wù)凧ava中Volatile關(guān)鍵字的理解
volatile這個(gè)關(guān)鍵字可能很多朋友都聽說過,或許也都用過。在Java 5之前,它是一個(gè)備受爭(zhēng)議的關(guān)鍵字,因?yàn)樵诔绦蛑惺褂盟鶗?huì)導(dǎo)致出人意料的結(jié)果,本文給大家介紹java中volatile關(guān)鍵字,需要的朋友參考下2016-03-03
IntelliJ?IDEA?2023版本創(chuàng)建Spring項(xiàng)目時(shí)Java只能選擇17或21的問題解決方法
spring-boot是一個(gè)基于Java的開源框架,用于快速構(gòu)建生產(chǎn)級(jí)別的應(yīng)用程序,這篇文章主要給大家介紹了關(guān)于IntelliJ?IDEA?2023版本創(chuàng)建Spring項(xiàng)目時(shí)Java只能選擇17或21的問題解決方法,需要的朋友可以參考下2024-07-07
IDEA報(bào)錯(cuò)之前言中不允許有內(nèi)容問題及解決
當(dāng)使用IntelliJ IDEA時(shí),可能會(huì)遇到報(bào)錯(cuò)信息“前言中不允許有內(nèi)容”,這通常是由于XML文件是以帶有BOM頭的UTF-8格式保存的,導(dǎo)致IDE的解析出錯(cuò),解決辦法是在IDEA中調(diào)整文件編碼設(shè)置為無BOM的UTF-8,然后用文本編輯器(如Notepad++)2024-10-10
RocketMQ設(shè)計(jì)之故障規(guī)避機(jī)制
這篇文章主要介紹了RocketMQ設(shè)計(jì)之故障規(guī)避機(jī)制,故障規(guī)避機(jī)制就是用來解決當(dāng)Broker出現(xiàn)故障,Producer不能及時(shí)感知而導(dǎo)致消息發(fā)送失敗的問題,下面詳細(xì)介紹需要的小伙伴可以參考一下2022-03-03
Java報(bào)錯(cuò)Java.text.ParseException的解決方法匯總
在Java開發(fā)的復(fù)雜世界中,錯(cuò)誤處理是開發(fā)者必須面對(duì)的關(guān)鍵挑戰(zhàn)之一,其中,Java.text.ParseException就像一個(gè)隱藏在代碼叢林中的陷阱,常常讓開發(fā)者們陷入困惑,本文給大家介紹了Java報(bào)錯(cuò)Java.text.ParseException的解決方法,需要的朋友可以參考下2024-10-10

