springboot整合Druid+mybatis

2023-11-03

Druid

Springboot集成Druid方案:一个是在POM中直接配置druid-spring-boot-starter,不用写任何代码;一个是配置druid,写几行代码,可以加入;在方案一基础上加入stat、wall后进行验证登录。

先献上github代码地址:https://github.com/yudiandemingzi/spring-boot-many-data-source
代码拉下来换下自己的mysql数据库地址,就可以直接运行。Druid的优点很明显,它的可视化界面可以监控Sql语句和URI执行情况在开发中真的很需要。

先说优点吧:

1) 替换DBCP和C3P0。Druid提供了一个高效、功能强大、可扩展性好的数据库连接池。
2) 数据库密码加密。直接把数据库密码写在配置文件中,这是不好的行为,容易导致安全问题。
3) 可以监控数据库访问性能,能够详细统计SQL的执行性能,这对于线上分析数据库访问性能有帮助。
4) SQL执行日志,Druid提供了不同的LogFilter,监控你应用的数据库   访问情况。
5)扩展JDBC,如果你要对JDBC层有编程的需求,可以通过Druid提供的Filter-Chain机制,很方便编写JDBC层的扩展插件。

com.alibaba.druid.pool.DruidDataSource 基本配置参数:

配置 缺省值 说明
name 配置这个属性的意义在于没如果存在多个数据源,监控的时候可以通过名字来区分开来。如果没有配置,将会生成一个名字,格式是"DataSource-"+System.identityHashCode(this)
jdbcUrl 连接数据库的url,不同数据库不一样
username 连接数据库的用户名
password 连接数据库的密码。如果你不希望密码直接写在配置文件中
driverClassName 根据url自动识别 这一项可配可不配,如果不配置druid会根据url自动识别dbType,然后选择相应的driverClassName(建议配置下)
initialSize 0 初始化时建立物理连接的个数,初始化发生在显示调用init方法,或者第一次getConnection时
maxActive 8 最大连接池数量
maxIdle 8 已经不再使用,配置了也没效果
minIdle 最小连接池数量
maxWait 获取连接时最大等待时间,单位毫秒,配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁
poolPreparedStatements false 是否缓存preparedStatement,也就是PsCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭
maxOpenPreparedStatements -1 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置打一下,比如说100
validationQuery 用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn 、testWhileIdle都不会起作用
testOnBorrow true 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
testOnReturn false 归还连接时执行它validationQuery检测连接是否有效,做了这个配置会降低性能
testWhileIdle false 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunMills,执行validationQuery检测连接是否有效
timeBetweenEvictionRunMillis 1分钟(1.0.14) 有两个含义:Destory线程会检测连接的间隔时间 testWhileIdle的判断依据,详细看testWhileIdele属性的说明
numTestsPerEvictionRun 不再使用,一个DruidDataSource只支持一个EvicationRun
minEvictableIdleTimeMillis 30分钟(1.0.14) 连接保持空闲而不被驱逐的最长时间
connectionInitSqls 物理连接初始化的时候执行sql
exceptionSorter 根据dbType自动识别 当数据库抛出一些不可恢复的异常时,抛弃连接
filters 属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:监控统计用的filter:stat日志用的filter;log4j防御注入的filter:wall
proxyFilters 类型是List<com.alibaba.druid,filter.Filter>,如果同时配置filter和proxyFilters,是组合关系,并非

配置数据源

1、添加上 Druid 数据源依赖。

 <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.6</version>
        </dependency>

2、切换数据源;之前已经说过 Spring Boot 2.0 以上默认使用 com.zaxxer.hikari.HikariDataSource 数据源,但可以 通过 spring.datasource.type 指定数据源。

spring:
  datasource:
    username: root
    password: 123456
    url: jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
    driver-class-name: com.mysql.cj.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource

3、数据源切换之后,在测试类中注入 DataSource,然后获取到它,输出一看便知是否成功切换;

@SpringBootTest
class SpringbootDataJdbcApplicationTests {
   

    @Autowired
    DataSource dataSource;

    @Test
    void contextLoads() throws SQLException {
   

        //查看默认数据源
        System.out.println(dataSource.getClass());

    }

}

在这里插入图片描述

4、切换成功!既然切换成功,就可以设置数据源连接初始化大小、最大连接数、等待时间、最小连接数 等设置项;可以查看源码


spring:
  datasource:
    username: root
    password: 123456
    #?serverTimezone=UTC解决时区的报错
    url: jdbc:mysql://localhost:3306/springboot?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
    driver-class-name: com.mysql.cj.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource

    #Spring Boot 默认是不注入这些属性值的,需要自己绑定
    #druid 数据源专有配置
    initialSize: 5
    minIdle: 5
    maxActive: 20
    maxWait: 60000
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    poolPreparedStatements: true

 
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

springboot整合Druid+mybatis 的相关文章

随机推荐

  • 线性回归算法及案例

    线性回归 寻找 一种能预测的趋势 回归问题的条件 前提 1 收集的数据 2 假设的模型 即一个函数 这个函数里含有未知的参数 通过学习 可以估计出参数 然后利用这个模型去预测 分类新的数据 案例 from sklearn datasets
  • DRBD分布式存储解决方案实战

    一 DRBD分布式存储解决方案 1 DRBD简介 DRBD的全称为 Distributed Replicated Block Device DRBD 分布式块设备复制 DRBD是由内核模块和相关脚本而构成 用以构建高可用性 HA 的集群 其
  • Cas5.3.2 服务端 自定义登入界面

    第一 项目整体结构 自定义页面涉及资源全部存放再src main resources 文件夹目录下 目录 含义 services 配置自定义登入网站模板 static 静态文件目录 用于存放js css代码的 templates 模板文件目
  • Linux mount 命令

    mount 命令用来挂载文件系统 其基本命令格式为 mount t type o options device dirdevice 指定要挂载的设备 比如磁盘 光驱等 dir 指定把文件系统挂载到哪个目录 type 指定挂载的文件系统类型
  • 使用Python,OpenCV执行视觉显著性检测(Visual Saliency Detection)

    使用Python OpenCV执行视觉显著性检测 Visual Saliency Detection 这篇博客将介绍如何使用Python OpenCV执行显著性检测 这是一个应用图像处理和计算机视觉算法来自动定位图像中最 显著 区域的过程
  • 使用python读取xml文件批量生成ground-truth标注图片

    目标检测中 在对比自己算法的检测效果时 需要和标注的真实值进行对比 在网上找到的大部分功能是一样的 只不过不完全符合画出真实标注的训练图片 import cv2 import numpy as np import xml dom minid
  • ASP.NET中新建Web网站并部署到IIS上(详细图文教程)

    场景 ASP NET中新建MVC项目并连接SqlServer数据库实现增删改查 https blog csdn net BADAO LIUMANG QIZHI article details 107024544 在上面实现了新建简单的MVC
  • String index out of range: 100 报错详解与解决方案

    问题出错情况 字符串截取长度 没有那么长的长度所以截取失败 在这里进行debug之后可以看到 异常在substring中 也就是判断字符串的时候报错 具体原因就是string字符串indexof的值本身只有5 然后在这里去取其第100 个字
  • MFC六大关键技术(4)——永久保存(串行化)

    MFC六大关键技术 第四部分 永久保存 串行化 先用一句话来说明永久保存的重要 弄懂它以后 你就越来越像个程序员了 如果我们的程序不需要永久保存 那几乎可以肯定是一个小玩儿 那怕我们的记事本 画图等小程序 也需要保存才有真正的意义 对于MF
  • Java项目之使用Bootstraptable批量操作

    Java项目之使用Bootstraptable批量操作 开发工具与关键技术 IntelliJ IDEA java 作者 刘剑鸿 撰写时间 2021 5 15 一开始认识一下bootstrap table插件介绍 它是一个基于bootstra
  • solr 服务器 配置文件,Solr的部署模式详解

    前言 本文介绍的Solr版本 solr 7 7 3 部署环境 windows Solr的两种部署模式 Solr程序包安装好后 可以以两种模式来启动solr服务器 Standalone Server 独立服务器模式 适用于数据规模不大的场景
  • 无人机运动场景下移动物体检测和跟踪系统

  • Python+pytest邮件发送测试报告,附件添加测试报告,邮件正文显示测试报告内容

    发送邮件测试报告 这个可以直接复制粘贴代码 都通用 我这个文件里还有其他的代码 导入的包比较多 单说发邮件的话 只导入邮件相关的几个就可以了 coding utf 8 import smtplib import time from emai
  • 真实项目案例实战——【状态设计模式】使用场景

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 写在前面 设计模式源于生活 而又高于生活 什么是状态模式 状态模式允许一个对象在其内部状态改变的时候改变其行为 这个对象看上去就像是改变了它的类一样 状态模式应用场景 1
  • Jetson XAVIAR NX 上安装tensorflow

    目录 JetPack 版本 安装过程 异常处理 1 train 时提示scikit learn 错误 2 tensorflow lite infer 时提示invoke 错误
  • TensorFlow学习(5)数据结构 & 自定义组件(损失函数,激活函数,初始化,正则化和约束,层)

    神经网络架构进一步学习 TensorFlow模型花园 1 数据结构 在使用之前先要导入tensorflow import tensorflow as tf 1 1 张量 1 1 1 通过直接传入创建 使用tf constant 创建张量 p
  • leetcode 5. 最长回文子串(c++)

    题目 思路分析 中心扩向两边的思想 根据回文串的性质 如str aba 从b出发 往两边同时遍历并比较字符是否相同即可 令left i 1 right i 1 那么依次比较str left str right 是否成立 如成立 继续比较 若
  • DASH(QTUM)Java对接

    下载钱包 https github com dashpay dash releases download v0 15 0 0 dashcore 0 15 0 0 win64 setup exe 配置文件 rpcuser rpcpasswor
  • 银行卡交易手续费介绍

    文章目录 转接清算费 转接清算费双向计收 转接清算费单向计收 交换费 转接清算费 银行卡清算机构收取的网络服务费 对于跨境交易的转接清算费是包含跨境交易服务费在内的多项费用合计金额 转接清算费双向计收 每笔交易银联分别向收单机构和发卡机构收
  • springboot整合Druid+mybatis

    Druid Springboot集成Druid方案 一个是在POM中直接配置druid spring boot starter 不用写任何代码 一个是配置druid 写几行代码 可以加入 在方案一基础上加入stat wall后进行验证登录