Druid 的整合 springboot mybaits

2024-05-10 02:38

本文主要是介绍Druid 的整合 springboot mybaits,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建 SpringBoot 项目

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

       创建 SpringBoot 和 Mybatis 的项目很简单,通过向导即可完成( 完整项目项目www.fhadmin.org)。创建项目后的依赖如下:

<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。有了依赖之后,添加数据库的配置,否则项目无法启动。数据库的配置如下:

spring:datasource:url: jdbc:mysql://192.168.0.106:3306/scms?serverTimezone=UTCusername: rootpassword:

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

//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,那么该如何做?

 

整合 Druid

        整合 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>

       修改数据库的配置只需要增加一行配置即可,配置如下:

spring:datasource:url: jdbc:mysql://192.168.0.106:3306/scms?serverTimezone=UTCusername: rootpassword:type: com.alibaba.druid.pool.DruidDataSource

       比较前面的配置,我们的配置增加了一行配置,然后我们接着运行前面的单元测试代码。输出如下:

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=UTCusername: rootpassword:type: com.alibaba.druid.pool.DruidDataSourceinitialSize: 5minIdle: 5maxActive: 20maxWait: 60000timeBetweenEvictionRunsMillis: 60000minEvictableIdleTimeMillis: 300000validationQuery: SELECT 1 FROM DUALtestWhileIdle: truetestOnBorrow: falsetestOnReturn: falsepoolPreparedStatements: 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")@Beanpublic 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 的监控界面

这篇关于Druid 的整合 springboot mybaits的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/975206

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis