Springboot集成Druid实现监控功能

Druid是阿里巴巴开发的号称为监控而生的数据库连接池,在功能、性能、扩展性方面,都超过其他数据库连接池,包括DBCP、C3P0、BoneCP、Proxool、JBoss DataSource等等等,秒杀一切。Druid可以很好的监控DB池连接和SQL的执行情况,天生就是针对监控而生的DB连接池。

官方的参考
https://github.com/alibaba/druid/wiki/%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98

一、传统web项目(如ssh,ssm)

<dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.23</version>
</dependency>

使用xml或配置类配置好DruidDataSource

<!--使用druid数据源--><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init"><!--注入连接属性--><property name="driverClassName" value="xxx"/><property name="url" value="xxx"/><property name="username" value="xxx"/><property name="password" value="xxx"/><!--初始化连接池大小--><property name="initialSize" value="5"></property><!--设置最大连接数--><property name="maxActive" value="20"></property><!--设置等待时间--><property name="maxWait" value="5000"/><!--配置数据源监控的filter--><property name="filters" value="stat"></property></bean>

在web应用中的WEB-INF/web.xml中进行相关配置 

	<servlet><servlet-name>StatViewServlet</servlet-name><servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class><!--登陆名--><init-param><param-name>loginUsername</param-name><param-value>admin</param-value></init-param><!-- 登录密码--><init-param><param-name>loginPassword</param-name><param-value>2024</param-value></init-param><!--白名单--><init-param><param-name>allow</param-name><param-value></param-value></init-param><!--黑名单--><init-param><param-name>deny</param-name><param-value></param-value></init-param></servlet><servlet-mapping><servlet-name>StatViewServlet</servlet-name><url-pattern>/druid/*</url-pattern></servlet-mapping><filter><filter-name>WebStatFilter</filter-name><filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class><!--过滤的样式--><init-param><param-name>exclusions</param-name><param-value>*.js,*.gif,*.css,*.ico,*.jpg,*.png,/druid/*</param-value></init-param></filter><filter-mapping><filter-name>WebStatFilter</filter-name><servlet-name>StatViewServlet</servlet-name></filter-mapping>

二、springboot中引入原生的druid,依赖和上面一样,编写配置类即可

import com.alibaba.druid.filter.Filter;
import com.alibaba.druid.filter.stat.StatFilter;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.wall.WallConfig;
import com.alibaba.druid.wall.WallFilter;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;@Configuration
public class DruidConfig {//登陆账号private final String USERNAME = "root";//登陆密码private final String PASSWORD = "123";@Value("${spring.datasource.url:#{null}}")private String dbUrl;@Value("${spring.datasource.username: #{null}}")private String username;@Value("${spring.datasource.password:#{null}}")private String password;@Value("${spring.datasource.driverClassName:#{null}}")private String driverClassName;/*** 以下属性可在配置文件自行定义*/private Integer initialSize = 5;private Integer minIdle = 10;private Integer maxActive = 20;private Integer maxWait = 60000;@Bean@Primarypublic DruidDataSource dataSource() {DruidDataSource datasource = new DruidDataSource();datasource.setUrl(this.dbUrl);datasource.setUsername(username);datasource.setPassword(password);datasource.setDriverClassName(driverClassName);if (initialSize != null) {datasource.setInitialSize(initialSize);}if (minIdle != null) {datasource.setMinIdle(minIdle);}if (maxActive != null) {datasource.setMaxActive(maxActive);}if (maxWait != null) {datasource.setMaxWait(maxWait);}List<Filter> filters = new ArrayList<>();filters.add(statFilter());filters.add(wallFilter());datasource.setProxyFilters(filters);return datasource;}@Beanpublic ServletRegistrationBean druidServlet() {ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean();servletRegistrationBean.setServlet(new StatViewServlet());servletRegistrationBean.addUrlMappings("/druid/*");Map<String, String> initParameters = new HashMap<>();//禁用HTML页面上的“Rest All”功能initParameters.put("resetEnable", "false");//ip白名单(没配置则允许所有访问)//initParameters.put("allow", "");//ip黑名单,如果某个ip同时存在,deny优先于allow//initParameters.put("deny", "");initParameters.put("loginUsername", USERNAME);initParameters.put("loginPassword", PASSWORD);servletRegistrationBean.setInitParameters(initParameters);return servletRegistrationBean;}@Beanpublic StatFilter statFilter() {StatFilter statFilter = new StatFilter();//慢sql记录statFilter.setLogSlowSql(true);statFilter.setMergeSql(true);//超过多少时间为慢sqlstatFilter.setSlowSqlMillis(3000);return statFilter;}@Beanpublic WallFilter wallFilter() {WallFilter wallFilter = new WallFilter();//允许执行多条SQLWallConfig config = new WallConfig();config.setMultiStatementAllow(true);wallFilter.setConfig(config);return wallFilter;}
}

三、springboot druid starter方式

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

按需配置application.yml的内容

spring:datasource:url: ******username: ******password: ******driver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSource  # 指定数据源类型######### 连接池 配置 ##########druid:# 配置初始化大小、最小、最大initial-size: 5minIdle: 10max-active: 20# 配置获取连接等待超时的时间(单位:毫秒)max-wait: 60000# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
#      time-between-eviction-runs-millis: 2000# 配置一个连接在池中最小生存的时间,单位是毫秒
#      min-evictable-idle-time-millis: 600000
#      max-evictable-idle-time-millis: 900000# 用来测试连接是否可用的SQL语句,默认值每种数据库都不相同,这是mysql
#      validationQuery: select 1# 应用向连接池申请连接,并且testOnBorrow为false时,连接池将会判断连接是否处于空闲状态,如果是,则验证这条连接是否可用
#      testWhileIdle: true# 如果为true,默认是false,应用向连接池申请连接时,连接池会判断这条连接是否是可用的
#      testOnBorrow: false# 如果为true(默认false),当应用使用完连接,连接池回收连接的时候会判断该连接是否还可用
#      testOnReturn: false# 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle
#      poolPreparedStatements: true# 要启用PSCache,必须配置大于0,当大于0时, poolPreparedStatements自动触发修改为true,# 在Druid中,不会存在Oracle下PSCache占用内存过多的问题,# 可以把这个数值配置大一些,比如说100
#      maxOpenPreparedStatements: 20# 连接池中的minIdle数量以内的连接,空闲时间超过minEvictableIdleTimeMillis,则会执行keepAlive操作
#      keepAlive: true# Spring 监控,利用aop 对指定接口的执行时间,jdbc数进行记录aop-patterns: "com.springboot.template.dao.*"########### 启用内置过滤器(第一个 stat必须,否则监控不到SQL)##########filters: stat,wall,log4j2# 自己配置监控统计拦截的filterfilter:# 开启druiddatasource的状态监控stat:enabled: truedb-type: mysql# 开启慢sql监控,超过2s 就认为是慢sql,记录到日志中log-slow-sql: trueslow-sql-millis: 2000# 日志监控,使用slf4j 进行日志输出
#        slf4j:
#          enabled: true
#          statement-log-error-enabled: true
#          statement-create-after-log-enabled: false
#          statement-close-after-log-enabled: false
#          result-set-open-after-log-enabled: false
#          result-set-close-after-log-enabled: false########## 配置WebStatFilter,用于采集web关联监控的数据 ##########web-stat-filter:# 启动 StatFilterenabled: true# 过滤所有urlurl-pattern: /*# 排除一些不必要的urlexclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"# 开启session统计功能session-stat-enable: true# session的最大个数,默认100session-stat-max-count: 1000########## 配置StatViewServlet(监控页面),用于展示Druid的统计信息 ##########stat-view-servlet:# 启用StatViewServletenabled: true# 访问内置监控页面的路径,内置监控页面的首页是/druid/index.htmlurl-pattern: /druid/*# 不允许清空统计数据,重新计算reset-enable: false# 配置监控页面访问密码login-username: rootlogin-password: 123# 允许访问的地址,如果allow没有配置或者为空,则允许所有访问
#        allow:# 拒绝访问的地址,deny优先于allow,如果在deny列表中,就算在allow列表中,也会被拒绝
#        deny:

访问监控页面

页面简单介绍 

1、数据源页面:是当前DataSource配置的基本信息,上述配置的Filter可以在里面找到,如果没有配置Filter(一些信息会无法统计,例如“SQL监控”,会无法获取JDBC相关的SQL执行信息)。
2、SQL监控页面:统计了所有SQL语句的执行情况。
3、URL监控页面:统计了所有Controller接口的访问以及执行情况。
4、Spring 监控页面,利用aop 对指定接口的执行时间,jdbc数进行记录。
5、SQL防火墙页面:druid提供了黑白名单的访问,可以清楚的看到sql防护情况。
6、Session监控页面:可以看到当前的session状况,创建时间、最后活跃时间、请求次数、请求时间等详细参数。
7、JSONAPI 页面:通过api的形式访问Druid的监控接口,api接口返回Json形式数据。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/485277.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

<网络安全>《47 网络攻防专业课<第十二课 - TCPIP网络协议攻击与防范之攻击手段>》

1 建立TCP连接 三次握手 2 SYN Flood泛洪攻击 服务拒绝&#xff08;DOS&#xff0c;Denial of Service&#xff09;攻击时&#xff0c;攻击者想法占用被攻击者的资源&#xff0c;例如&#xff1a;带宽、CPU、内存等&#xff0c;使得被攻击者无法响应正常用户的请求。 SYN泛洪…

mysql 自定义函数create function

方便后续查询&#xff0c;做以下记录&#xff1b; 自定义函数是一种与存储过程十分相似的过程式数据库对象&#xff0c; 它与存储过程一样&#xff0c;都是由 SQL 语句和过程式语句组成的代码片段&#xff0c;并且可以被应用程序和其他 SQL 语句调用。 自定义函数与存储过程之间…

【机器学习的基本术语和概念】

曾梦想执剑走天涯&#xff0c;我是程序猿【AK】 目录 简述概要知识图谱 简述概要 提示&#xff1a;简要描述文章内容&#xff0c;适合哪些人观看 知识图谱 样本&#xff08;Sample&#xff09;/实例&#xff08;Instance&#xff09;&#xff1a;在机器学习中&#xff0c;我…

创建一个基于Node.js的实时聊天应用

在当今数字化社会&#xff0c;实时通讯已成为人们生活中不可或缺的一部分。无论是在社交媒体平台上与朋友交流&#xff0c;还是在工作场合中与同事协作&#xff0c;实时聊天应用都扮演着重要角色。与此同时&#xff0c;Node.js作为一种流行的后端技术&#xff0c;为开发者提供了…

【2024.02.22】定时执行专家 V7.0 发布 - TimingExecutor V7.0 Release - 龙年春节重大更新版本

目录 ▉ 新版本 V7.0 下载地址 ▉ V7.0 新功能 ▼2024-02-21 V7.0 - 更新日志▼ ▉ V7.0 新UI设计 ▉ 新版本 V7.0 下载地址 BoomWorks软件的最新版本-CSDN博客文章浏览阅读10w次&#xff0c;点赞9次&#xff0c;收藏41次。▉定时执行专家—毫秒精度、专业级的定时任务执行…

大学生课程版|统计基础与python分析|一元线性回归

目录 1.一元线性回归的数学原理 2.一元线性回归的代码实现 2.1需要安装sklearn库 2.2绘制离散点图 2.3引入Scikit-Learn库搭建模型 2.4 模型预测 2.5 模型可视化 摘要&#xff1a;线性回归模型是利用线性拟合的方式来探寻数据背后的规律&#xff0c;如下图所示&#xff…

设计模式——抽象工厂模式

定义: 抽象工厂模式&#xff08;Abstract Factory Pattern&#xff09;提供一个创建一系列或相互依赖对象的接口&#xff0c;而无须指定它们具体的类。 概述:一个工厂可以提供创建多种相关产品的接口&#xff0c;而无需像工厂方法一样&#xff0c;为每一个产品都提供一个具体…

HarmonyOS—使用预览器查看应用/服务效果

DevEco Studio为开发者提供了UI界面预览功能&#xff0c;可以查看应用/服务的UI界面效果&#xff0c;方便开发者随时调整界面UI布局。预览器支持布局代码的实时预览&#xff0c;只需要将开发的源代码进行保存&#xff0c;就可以通过预览器实时查看应用/服务运行效果&#xff0c…

Jetpack Compose 可组合项的生命周期

点击查看&#xff1a;可组合项的生命周期 官网 在本页中&#xff0c;您将了解可组合项的生命周期以及 Compose 如何确定可组合项是否需要重组。 生命周期概览 正如管理状态文档中所述&#xff0c;一个组合将描述应用的界面&#xff0c;并通过运行可组合项来生成。组合是描述…

算能RISC-V通用云开发空间编译pytorch @openKylin留档

终于可以体验下risc-v了&#xff01; 操作系统是openKylin&#xff0c;算能的云空间 尝试编译安装pytorch 首先安装git apt install git 然后下载pytorch和算能cpu的库&#xff1a; git clone https://github.com/sophgo/cpuinfo.git git clone https://github.com/pytorc…

2.5网安学习第二阶段第五周回顾(个人学习记录使用)

本周重点 ①多进程和多线程 1、进程和线程 2、多线程爆破 ②Redis数据库 1、Redis的使用 2、Redis持久化 3、Redis未授权免密登录 ③嗅探和Python攻击脚本 1、嗅探&#xff08;端口扫描和IP扫描&#xff09; 2、SCAPY的应用 3、Python攻击脚本&#xff08;SYN半连接…

CI/CD 之 gitlab-runner 部署与踩坑

前言 去年花时间研究了一下 CI/CD , 自己部署了一套 gitlab-runner 玩了一下&#xff0c;部署过程之后遇到了不少问题&#xff0c;把之前的踩坑与部署记录分享一下。 简介 gitlab-runner是一个开源项目&#xff0c;用于运行 Pipeline 作业并将结果发送回 GitLab。 它与 Git…