Druid 的整合 springboot mybaits

建立 SpringBoot 项目css

       在整合 Druid 以前,须要先建立一个 SpringBoot 和 MyBatis 的项目,先来观察一下,它默认是否使用了数据库链接池,使用了什么数据库链接池。而后,再来整合 Druid 这款数据库链接池到项目当中。html

       建立 SpringBoot 和 Mybatis 的项目很简单,经过向导便可完成( 完整项目项目www.fhadmin.org)。建立项目后的依赖以下:java

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.3</version>
</dependency>

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
    <exclusions>
        <exclusion>
            <groupId>org.junit.vintage</groupId>
            <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
    </exclusions>
</dependency>

       其中的依赖不多,添加了 SpringMVC、Mybatis 和 MySQL。有了依赖以后,添加数据库的配置,不然项目没法启动。数据库的配置以下:mysql

spring:
    datasource:
        url: jdbc:mysql://192.168.0.106:3306/scms?serverTimezone=UTC
        username: root
        password:

       有了上面的配置,项目就能够启动了,不过整个项目没有任何功能启动也无心义。所以来写一个简单的单元测试,代码以下:web

//www.fhadmin.org
@Autowired
DataSource dataSource;

@Test
void contextLoads() throws SQLException
{
    System.out.println(dataSource.getClass());
    Connection connection = dataSource.getConnection();
    System.out.println(connection);
}

       有了单元测试以后,直接运行单元测试的代码,输出结果以下:
class com.zaxxer.hikari.HikariDataSource
2020-10-02 11:17:41.279  INFO 25817 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Starting...
2020-10-02 11:17:41.457  INFO 25817 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Start completed.
HikariProxyConnection@1405548909 wrapping com.mysql.cj.jdbc.ConnectionImpl@435cc7f9
2020-10-02 11:17:41.472  INFO 25817 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown initiated...
2020-10-02 11:17:41.482  INFO 25817 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown completed.

       能够看到,虽然在项目中没有整合任何的数据库链接池,可是 Spring 默认整合了 Hikari 这个数据库链接池。可是,咱们想要使用的是 Druid,那么该如何作?spring


整合 Druidsql

        整合 Druid 的方法也比较简单的,引入 Druid 的相关依赖,并修改数据库的配置便可。依赖以下:数据库

<!-- https://mvnrepository.com/artifact/com.alibaba/druid 完整项目项目www.fhadmin.org -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.24</version>
</dependency>

       修改数据库的配置只须要增长一行配置便可,配置以下:mybatis

spring:
    datasource:
        url: jdbc:mysql://192.168.0.106:3306/scms?serverTimezone=UTC
        username: root
        password:
        type: com.alibaba.druid.pool.DruidDataSource

       比较前面的配置,咱们的配置增长了一行配置,而后咱们接着运行前面的单元测试代码。输出以下:app

class com.alibaba.druid.pool.DruidDataSource
2020-10-02 12:01:18.784  INFO 26316 --- [           main] com.alibaba.druid.pool.DruidDataSource   : {dataSource-1} inited
com.mysql.cj.jdbc.ConnectionImpl@3f0d6038
2020-10-02 12:01:18.920  INFO 26316 --- [extShutdownHook] com.alibaba.druid.pool.DruidDataSource   : {dataSource-1} closing ...
2020-10-02 12:01:18.921  INFO 26316 --- [extShutdownHook] com.alibaba.druid.pool.DruidDataSource   : {dataSource-1} closed
2020-10-02 12:01:18.922  INFO 26316 --- [extShutdownHook] o.s.s.concurrent.ThreadPoolTaskExecutor  : Shutting down ExecutorService 'applicationTaskExecutor'

        能够看到,数据库链接池已经变成了 alibaba 的 Druid 了。

       固然了,这不能算完,由于数据库链接池仍是有不少配置的,咱们添加一些配置,配置以下:

spring:
    datasource:
        url: jdbc:mysql://192.168.0.106:3306/scms?serverTimezone=UTC
        username: root
        password:
        type: com.alibaba.druid.pool.DruidDataSource
        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

        上面的配置对 Druid 进行相关的配置,可是添加上配置是否能生效,修改咱们的单元测试代码并运行,单元测试代码修改以下:

DruidDataSource druidDataSource = (DruidDataSource)dataSource;
System.out.println("initialSize: " + druidDataSource.getInitialSize());
System.out.println("maxActive: " + druidDataSource.getMaxActive());

       运行修改后的单元测试,查看输出:

initialSize: 0
maxActive: 8

       能够看到,并无按照咱们的预期进行输出,由于配置并无被读取。咱们须要可以将修改的配置进行读取。

读取数据库链接池配置

        想要使用数据库链接池的配置,那么就须要定义一个读取配置的类,并从新实例化一个 DataSource 类。代码以下:

//完整项目项目fhadmin.org
@Configuration
public class DruidConfig
{
    @ConfigurationProperties(prefix = "spring.datasource")
    @Bean
    public DataSource druidDataSource() {
        return new DruidDataSource();
    }
}

       再次运行单元测试,查看输出:
initialSize: 5
maxActive: 20

        能够看到,如今的输出结果已经和配置相同了。

配置监控

        在前面已经提到过,Druid 有强大的监控功能,可是须要咱们进行简单的代码编写才能够进行查看具体的监控,代码以下;

@Bean
public ServletRegistrationBean druidServletRegistrationBean()
{
    ServletRegistrationBean<Servlet> servletServletRegistrationBean = new ServletRegistrationBean<>(new StatViewServlet(), "/druid/*");;
    Map<String, String> initParam = new HashMap<>();
    //后台容许谁能够访问
    initParam.put("loginUsername", "admin");
    initParam.put("loginPassword", "123456");
    initParam.put("allow", "");
    servletServletRegistrationBean.setInitParameters(initParam);

    return servletServletRegistrationBean;
}

// 配置 Druid 监控 之  web 监控的 filter
// WebStatFilter:用于配置Web和Druid数据源之间的管理关联监控统计
@Bean
public FilterRegistrationBean webStatFilter() {
    FilterRegistrationBean bean = new FilterRegistrationBean();
    bean.setFilter(new WebStatFilter());

    Map<String, String> initParams = new HashMap<>();
    initParams.put("exclusions", "*.js,*.css,/druid/*");
    bean.setInitParameters(initParams);

    //"/*" 表示过滤全部请求
    bean.setUrlPatterns(Arrays.asList("/*"));
    return bean;
}


       启动项目,而后访问 localhost:8080/druid/ 就会进入 Druid 的监控界面

相关文章
相关标签/搜索