Springboot 整合 durid

news/2024/10/8 22:50:39 标签: spring boot, java, 后端

文章目录

    • Springboot 整合 druid
      • druid的优势
      • 配置参数
      • 使用
        • 整合 Druid
        • 配置数据源
        • 配置参数
        • 绑定配置参数
        • 配置监控页面
        • 配置拦截器

Springboot 整合 druid

druid的优势

  • 可以很好的监控 DB 池连接 和 SQL 的执行情况
  • 可以给数据库密码加密
  • 可以很方便的编写JDBC插件

配置参数

在这里插入图片描述

使用

整合 Druid

导入 Druid 数据源依赖

配置数据源

在这里插入图片描述

配置参数

在这里插入图片描述

spring:
  datasource:
   #数据源基本配置
    username: root
    password: 123456
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/ssm_crud
    type: com.alibaba.druid.pool.DruidDataSource
   #数据源其他配置
    druid:
      #配置初始化大小、最小、最大线程数
      initialSize: 5
      minIdle: 5
      #CPU核数+1,也可以大些但不要超过20,数据库加锁时连接过多性能下降
      maxActive: 20
     # 最大等待时间,内网:800,外网:1200(三次握手1s)
      maxWait: 60000
      timeBetweenEvictionRunsMillis: 60000
     #配置一个连接在池中最大空间时间,单位是毫秒
      minEvictableIdleTimeMillis: 300000
      validationQuery: SELECT 1 
      testWhileIdle: true
     # 设置从连接池获取连接时是否检查连接有效性,true检查,false不检查
      testOnBorrow: true
      # 设置从连接池归还连接时是否检查连接有效性,true检查,false不检查
      testOnReturn: true
      #可以支持PSCache(提升写入、查询效率)
      poolPreparedStatements: true
      #配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙  
      filters: stat,wall,log4j
      maxPoolPreparedStatementPerConnectionSize: 20
      useGlobalDataSourceStat: true  
      connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
绑定配置参数

在这里插入图片描述

配置监控页面

在这里插入图片描述

配置拦截器

在这里插入图片描述

@Configuration
public class DruidConfig {

    @Bean
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource getMyDruidDataSource(){
        return new DruidDataSource();
    }

    //配置Druid的监控
    //1.配置一个管理后台的Servlet
    @Bean
    public ServletRegistrationBean statViewServlet(){
        // 记得加上"/druid/*",否则在进行登录页面的重定向过多而无法访问的问题(记得在Google浏览器才会报这个错)
        ServletRegistrationBean<StatViewServlet> bean = new ServletRegistrationBean<>(new StatViewServlet(),"/druid/*");
        Map<String,String> initParams = new HashMap<>();

        initParams.put("loginUsername","admin");
        initParams.put("loginPassword","123456");
        //默认是允许所有访问
        //initParams.put("allow","");
//        initParams.put("deny","192.168.31.30");
        bean.setInitParameters(initParams);
        return bean;
    }
    //2.配置一个web监控的filter
    @Bean
    public FilterRegistrationBean webStatFilter(){
        FilterRegistrationBean bean = new FilterRegistrationBean();
        bean.setFilter(new WebStatFilter());

        Map<String,String> initParams = new HashMap<>();
        //配置拦截时需要排除的请求
        initParams.put("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        bean.setInitParameters(initParams);

        bean.setUrlPatterns(Arrays.asList("/*"));

        return bean;

    }
}

在这里插入图片描述


http://www.niftyadmin.cn/n/5694912.html

相关文章

操作系统 | 学习笔记 | 王道 | 4.2 目录

4.2 目录 4.2.1 目录的基本概念 文件目录指FCB的有序集合&#xff0c;一个FCB就是一个文件的目录项。与文件管理系统和文件集合相关联的是文件目录&#xff0c;它包含有关文件的属性、位置和所有权等。 目录管理的基本要求&#xff1a; 从用户的角度看&#xff0c;目录在用户…

python爬虫 - 进阶requests模块

&#x1f308;个人主页&#xff1a;https://blog.csdn.net/2401_86688088?typeblog &#x1f525; 系列专栏&#xff1a;https://blog.csdn.net/2401_86688088/category_12797772.html 目录 前言 一、SSL证书问题 &#xff08;一&#xff09;跳过 SSL 证书验证 &#xff0…

crossover软件如何安装程序 及最新图文案张教程

IT之家 2 月 23 日消息&#xff0c;CodeWeavers 近日发布了 CrossOver 24 版本更新&#xff0c;基于近期发布的 Wine 9.0&#xff0c;不仅兼容更多应用和游戏&#xff0c;还初步支持运行 32 位应用程序。 苹果在 macOS Catalina 系统中移除对 32 位软件的支持之后&#xff0c;在…

No.7 笔记 | 数据库基础(含端口号)

一、数据库概述 &#xff08;一&#xff09;概念与结构 定义 数据库是一个按照特定结构组织、存储和管理数据的电子仓库。用户可以对其中的数据进行各种操作&#xff0c;如查询、插入、更新和删除。例如&#xff0c;智能手机中的通讯录就是一种简单的数据库形式。 层次结构…

GeoShp:shapefile转geojson支持nodejs和浏览器

GeoShp 概述 GeoShp 是一个轻量级的 JavaScript 库&#xff0c;允许您解析 Shapefile&#xff08;.shp 和 .dbf&#xff09;文件并将其转换为 GeoJSON 对象。它支持 Node.js 和浏览器环境&#xff0c;并且可以与 CommonJS 和 ES Modules 兼容。GeoShp 不依赖任何外部库&#…

ssm图书管理系统的设计与实现

系统包含&#xff1a;源码论文 所用技术&#xff1a;SpringBootVueSSMMybatisMysql 免费提供给大家参考或者学习&#xff0c;获取源码请私聊我 需要定制请私聊 目 录 摘 要 I Abstract II 第1章 绪论 1 1.1 课题研究背景 1 1.2课题研究现状 1 1.3课题实现目的和意义 …

Word转PDF的转换方法有哪些?这7个效率技巧,不知道就亏大了!

Word转PDF怎么转&#xff1f;我们在日常工作生活中&#xff0c;经常会用到word文档。如果是编写报告、做会议记录、制定文案等内容&#xff0c;一般都会选择创建word文档。但是如果需要发送给同事、客户或合作伙伴协作时&#xff0c;pdf格式会更加方便。 那么如何将word转为pdf…

使用CMake构建C动态库

文章目录 概要为什么目的设想工作空间代码代码结构库Private implementationPublic implementation编译一切使用库 概要 这篇文章的目的是提供一个示例&#xff0c;介绍如何在 Linux 中使用 CMake 作为构建工具来创建 C 共享库。 为什么 我找不到一个清晰而简单的示例来说明…