• SpringBoot2.0数据访问之整合数据源(Druid)


    1. SQL

    1.1 数据源的自动配置

            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-data-jdbcartifactId>
            dependency>
    
    • 1
    • 2
    • 3
    • 4

    为什么导入JDBC场景,官方不导入驱动?官方不知道我们接下要操作什么数据库。
    数据库版本和驱动版本对应
    默认版本:8.0.22

    默认版本(不进行版本配置,SpringBoot会自动配置版本):
            <dependency>
                <groupId>mysqlgroupId>
                <artifactId>mysql-connector-javaartifactId>
    
            dependency>
    想要修改版本
    1、直接依赖引入具体版本,如注释掉的部分(maven的就近依赖原则)
    2、重新声明版本(maven的属性的就近优先原则)
        <properties>
            <java.version>1.8java.version>
            <mysql.version>5.1.49mysql.version>
        properties>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    1.2 自动配置的类

    1、自动配置的类
      ● DataSourceAutoConfiguration : 数据源的自动配置
        ○ 修改数据源相关的配置:spring.datasource(配置文件中)
        ○ 数据库连接池的配置,是自己容器中没有DataSource才自动配置的
        ○ 底层配置好的连接池是:HikariDataSource

    	@Configuration(proxyBeanMethods = false)
    	@Conditional(PooledDataSourceCondition.class)
    	@ConditionalOnMissingBean({ DataSource.class, XADataSource.class })
    	@Import({ DataSourceConfiguration.Hikari.class, DataSourceConfiguration.Tomcat.class,
    			DataSourceConfiguration.Dbcp2.class, DataSourceConfiguration.OracleUcp.class,
    			DataSourceConfiguration.Generic.class, DataSourceJmxConfiguration.class })
    	protected static class PooledDataSourceConfiguration
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

      ● DataSourceTransactionManagerAutoConfiguration: 事务管理器的自动配置

      ● JdbcTemplateAutoConfiguration: JdbcTemplate的自动配置,可以来对数据库进行crud
        ○ 可以修改这个配置项@ConfigurationProperties(prefix = “spring.jdbc”) 来修改JdbcTemplate
        ○ @Bean@Primary JdbcTemplate;容器中有这个组件

      ● JndiDataSourceAutoConfiguration: jndi的自动配置

      ● XADataSourceAutoConfiguration: 分布式事务相关的

    1.3 修改配置项

    spring:
      datasource:
        url: jdbc:mysql://localhost:3306/db_account
        username: root
        password: 123456
        driver-class-name: com.mysql.jdbc.Driver
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    1.2 使用Druid数据源

    Druid数据源的官方参考文档:使用文档下载

    整合第三方技术的两种方式:
      ●自定义对第三方文件进行配置

    1、导入Druid数据源相关依赖

    
            <dependency>
                <groupId>com.alibabagroupId>
                <artifactId>druidartifactId>
                <version>1.1.17version>
            dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在Spring原生方法中需要往容器中放置相关组件:

    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
    		destroy-method="close">
    		<property name="url" value="${jdbc.url}" />
    		<property name="username" value="${jdbc.username}" />
    		<property name="password" value="${jdbc.password}" />
    		<property name="maxActive" value="20" />
    		<property name="initialSize" value="1" />
    		<property name="maxWait" value="60000" />
    		<property name="minIdle" value="1" />
    		<property name="timeBetweenEvictionRunsMillis" value="60000" />
    		<property name="minEvictableIdleTimeMillis" value="300000" />
    		<property name="testWhileIdle" value="true" />
    		<property name="testOnBorrow" value="false" />
    		<property name="testOnReturn" value="false" />
    		<property name="poolPreparedStatements" value="true" />
    		<property name="maxOpenPreparedStatements" value="20" />
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在Springboot中,需要写相关配置类:

      ● 在Springboot项目中,使用start的环境配置
    在这里插入图片描述
    属性配置:
    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述
    Druid数据源自动配置

    @Configuration
    @ConditionalOnClass({DruidDataSource.class})
    @AutoConfigureBefore({DataSourceAutoConfiguration.class})
    @EnableConfigurationProperties({DruidStatProperties.class, DataSourceProperties.class})
    @Import({DruidSpringAopConfiguration.class, DruidStatViewServletConfiguration.class, DruidWebStatFilterConfiguration.class, DruidFilterConfiguration.class})
    public class DruidDataSourceAutoConfigure {
        private static final Logger LOGGER = LoggerFactory.getLogger(DruidDataSourceAutoConfigure.class);
    
        public DruidDataSourceAutoConfigure() {
        }
    
        @Bean(
            initMethod = "init"
        )
        @ConditionalOnMissingBean
        public DataSource dataSource() {
            LOGGER.info("Init DruidDataSource");
            return new DruidDataSourceWrapper();
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    分析自动配置:
    配置项就是在properties配置文件中对组件属性进行修改的前缀
    ● 扩展配置项 spring.datasource.druid(@ConfigurationProperties(“spring.datasource.druid”))

    在自动配置类中添加了@Import({DruidSpringAopConfiguration.class, DruidStatViewServletConfiguration.class, DruidWebStatFilterConfiguration.class, DruidFilterConfiguration.class})
    ● DruidSpringAopConfiguration.class, 监控SpringBean的;配置项:spring.datasource.druid.aop-patterns
    ● DruidStatViewServletConfiguration.class, 监控页的配置:spring.datasource.druid.stat-view-servlet;默认开启
    ● DruidWebStatFilterConfiguration.class, web监控配置;spring.datasource.druid.web-stat-filter;默认开启
    ● DruidFilterConfiguration.class}) 所有Druid自己filter的配置,配置的filter如下

    public class DruidFilterConfiguration {
        private static final String FILTER_STAT_PREFIX = "spring.datasource.druid.filter.stat";
        private static final String FILTER_CONFIG_PREFIX = "spring.datasource.druid.filter.config";
        private static final String FILTER_ENCODING_PREFIX = "spring.datasource.druid.filter.encoding";
        private static final String FILTER_SLF4J_PREFIX = "spring.datasource.druid.filter.slf4j";
        private static final String FILTER_LOG4J_PREFIX = "spring.datasource.druid.filter.log4j";
        private static final String FILTER_LOG4J2_PREFIX = "spring.datasource.druid.filter.log4j2";
        private static final String FILTER_COMMONS_LOG_PREFIX = "spring.datasource.druid.filter.commons-log";
        private static final String FILTER_WALL_PREFIX = "spring.datasource.druid.filter.wall";
        private static final String FILTER_WALL_CONFIG_PREFIX = "spring.datasource.druid.filter.wall.config";
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    配置示例:

    spring:
      datasource:
        url: jdbc:mysql://119.3.69.247:3306/Mybatis
        username: root
        password: 1q2w3e4R!@
        driver-class-name: com.mysql.jdbc.Driver
    
        druid:
          aop-patterns: com.atguigu.admin.*  #springbean监控
          filters: stat,wall,slf4j  #所有开启的功能
    
          stat-view-servlet:  #监控页配置
            enabled: true
            login-username: admin  #监控页的配置,访问监控页必须按此账号密码登录
            login-password: admin
            reset-enable: false
    
          web-stat-filter: #web监控功能
            enabled: true
            url-pattern: /*
            exclusions: '*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*'
    
    
          filter:
            stat: #sql监控
              slow-sql-millis: 1000
              logSlowSql: true
              enabled: true
            wall: #防火墙
              enabled: true
              config:
                drop-table-allow: false
    
    • 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
    • 29
    • 30
    • 31
    • 32
  • 相关阅读:
    freeCAD不合并导入step文件
    ChatGPT搭建AI网站实战
    nodejs开发的小程序 老年人健康预警系统
    WebDAV之π-Disk派盘 + 纸间书摘
    在金融服务行业数字化转型中,低代码值得被关注
    【二、安装centOS】
    【Java集合类面试二十】、请介绍LinkedHashMap的底层原理
    Python 爬虫实战 | 利用多线程爬取 LOL 高清壁纸
    MySQL学习笔记(一 mysql简介)
    降低打新的预期
  • 原文地址:https://blog.csdn.net/lyy_sss/article/details/126286559