当我们在企业开发时,整合数据库连接池是进监控一个至关重要的组成部分。一个优秀的查询数据库连接池可以显著提高应用程序的性能和可伸缩性。在Java生态系统中,整合有很多连接池:Druid、进监控HikariCP、查询C3P0等等,大部分都是使用Druid或者SpringBoot默认HikariCP!
Druid有完整的SQL监控平台,下面来介绍和搭建一下吧!
<dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.15</version></dependency>
为了方便打印慢SQL我们把慢SQL时间调的小一点。
server: port: 8087spring: datasource: #使用阿里的Druid type: com.alibaba.druid.pool.DruidDataSource driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC username: root password: druid: statViewServlet: # Druid监控页面配置 enabled: true # 启用Druid监控页面 login-username: root # 监控页面登录用户名 login-password: root # 监控页面登录密码 url-pattern: /druid/* # 监控页面的访问URL路径 web-stat-filter: # Druid Web统计过滤器配置 enabled: true # 启用Web统计过滤器 session-stat-enable: true # 启用会话统计功能 session-stat-max-count: 1000 # 最大会话统计数量 filter: # Druid过滤器配置 stat: # SQL统计过滤器配置 enabled: true # 启用SQL统计过滤器 log-slow-sql: true # 启用慢SQL日志记录 slow-sql-millis: 10 # 慢SQL的执行时间阈值(单位:毫秒)mybatis-plus: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
「强烈注意」:Spring Boot 2.X 版本不再支持配置继承,多数据源的话每个数据源的所有配置都需要单独配置,否则配置不会生效!
详情可以去官方Github上看一下文档:
Druid官方文档:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter
实体类什么的都省略了。
@GetMapping("/listTest")public Result listTest(){ return Result.success(testService.list(Wrappers.<Test>lambdaQuery().like(Test::getName, "d方")));}
访问路径:http://localhost:8087/druid/index.html。
点击SQL监控,查看SQL执行的耗时情况,广告很显眼,刚刚也说了这是缺点,觉得不能忍受的可以去掉,百度一搜全是,这里就不展示了哈!
在日志里也会打印:
这样就简单的完成了SQL监控、慢SQL的查看,进而能够进行优化,提高系统效率!功能其实挺多的,大家可以挨个点开看看,要开启Spring监控要使用AOP对特定的接口做单独的监控!
责任编辑:姜华 来源: 小王博客基地 JavaDruid(责任编辑:热点)
上市公司短期融资券融资规模同比增91.77% 进一步完善发债制度
华阳股份(600348.SH)公布消息:拟开展应收账款保理业务
银保监会: 督促银行机构筑牢内控合规“防火墙” 夯实高质量发展根基
证监会等三部门发布QFII、RQFII新规 自2020年11月1日起施行