在项目中使用阿里的druid连接池,pom文件配置:
1
2
3
4
5
6
7
8
9
10
|
< 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配置,官方文档可查:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
# 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配置,说明请参考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配置,说明请参考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,搞定~
接下来,启动项目,打开地址:http://localhost:8080/druid
页面长这样:
我来请求一下接口,查询sql,确实监控到了:
补充知识:druid 配置理解及监控界面参数理解
druid 配置理解
官方文档中的很多配置,不是太理解或者貌似理解了,自己不实践一下,心里也不踏实,所以决定自己搞一个demo测试一下理解理解各个配置到底是什么意思
一、druidDataSource 配置
参数名称 | 我的理解 | 官方说明 |
---|---|---|
pool-prepared-statements | preparedStatement的创建会消耗很多的系统资源,同样的sql可以重用preparedStatement | 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭 |
initial-size | 初始化连接数 | 连接池建立时创建的初始化连接数 |
max-pool-prepared-statement-per-connection-size | 这个我不是太确定,这个应该是PSCache的缓存大小吧,官方说可以给大一点,单位也不清楚,那就给100吧 | … |
validation-query | 这个配置还是很容易理解的,关键是怎么去验证一下,比如在testOnBorrow=true,当申请链接时,确实会执行validation-query.我是这样验证的,validation-query=select 1 from dualss(有语法错误的sql),结果在申请链接的时候就报错了,证明在testOnBorrow的时候确实执行了validation-query,后面的testOnReturn,testWhileIdle我没有验证,应该都一样 | 用来检测连接是否有效的sql,要求是一个查询语句,常用select ‘x'。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。 |
validation-query-timeout | 不知道怎么验证 | … |
test-on-borrow | 不知道怎么验证,因为无论是true,还是false,只要validation-query有值,都会执行一下validation-query | |
test-on-return | 不知道怎么验证 | |
test-while-idle | 不知道怎么验证 | |
time-between-eviction-runs-millis | 默认是1分钟,就是destory每隔1分钟会执行一次 |
二、后台监控页面中的各数值的含义
我的端口是8585,就是如下图这个界面中每行
参数名称 | 中文 | 我的理解 | 官方说明 |
---|---|---|---|
ActiveCount | 活跃连接数 | 有n个连接正在执行sql,那么这个值就为n | 当前连接池中活跃连接数 |
InitialSize | 初始化连接大小 | 默认就是项目启动就会初始化的连接数 | 连接池建立时创建的初始化连接数 |
LogicConnectCount | 逻辑连接打开次数 | 与MaxActive没有关系,连接被用一次,LogicConnectCount就会+1,就是连接池中的连接被用次数综合 | 产生的逻辑连接建立总数 |
minEvictableIdleTimeMillis | 连接保持空闲而不被驱逐的最小时间 |
以上这篇SpringBoot集成Druid监控页面最小化配置操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/xqnode/article/details/88377296