服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - SpringBoot数据访问自定义使用Druid数据源的方法

SpringBoot数据访问自定义使用Druid数据源的方法

2021-11-09 11:46xbhog Java教程

本文记录Druid数据源的使用,自定义实现Drud的功能、监控页、登录、统计等。对SpringBoot数据访问使用Druid数据源的相关知识感兴趣额朋友一起看看吧

SpringBoot数据访问自定义使用Druid数据源的方法

数据访问之druid数据源的使用

说明:该数据源druid,使用自定义方式实现,后面文章使用start启动器实现,学习思路为主。

为什么要使用数据源:

​数据源是提高数据库连接性能的常规手段,数据源会负责维持一个数据连接池,当程序创建数据源实例时,系统会一次性地创建多个数据库连接,并把这些数据库连接保存在连接池中。

​当程序需要进行数据库访问时,无须重新获得数据库连接,而是从连接池中取出一个空闲的数据库连接。

​当程序使用数据库连接访问数据库结束后,无须关闭数据库连接,而是将数据库连接归还给连接池即可。

​通过这种方式,就可避免频繁地获取数据库连接、关闭数据库连接所导致的性能下降

为什么要使用数据源

数据源是提高数据库连接性能的常规手段,数据源会负责维持一个数据连接池,当程序创建数据源实例时,系统会一次性地创建多个数据库连接,并把这些数据库连接保存在连接池中。当程序需要进行数据库访问时,无须重新获得数据库连接,而是从连接池中取出一个空闲的数据库连接。当程序使用数据库连接访问数据库结束后,无须关闭数据库连接,而是将数据库连接归还给连接池即可。通过这种方式,就可避免频繁地获取数据库连接、关闭数据库连接所导致的性能下降。

druid官方github地址

druid中文文档

druid的介绍以及优点:

druid是阿里巴巴开源平台上一个数据库连接池实现,它不但结合了c3p0、dbcp、proxool等数据库连接池的优点,同时还加入了日志监控,可以分别监控db池连接和sql的执行情 况,是一款针对监控而生的数据库连接池

整合第三方技术的两种方式

  • 自定义
  • 找starter

自定义实现druid数据源

引入数据源

博主版本:1.2.6

?
1
2
3
4
5
<dependency>
    <groupid>com.alibaba</groupid>
    <artifactid>druid</artifactid>
    <version>版本号</version>
</dependency>

配置数据源

因为在引入数据源,springboot默配置的数据源是hikaridatasource,所以我们如果要使用druid的话,需要自己创建一个数据源,并放到容器中使用,mydatasourceconfig文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import com.alibaba.druid.pool.druiddatasource;
import org.springframework.context.annotation.bean;
import org.springframework.context.annotation.configuration;
 
import javax.sql.datasource;   //注意不要导错包
 
@configuration
//配置数据源
public class mydtasourceconfig {
    @bean
    public datasource datasource() {
 
        return new druiddatasource();   //创建druid数据源
    }
}

为什么我们创建的数据源可以使用呢?

在datasourceautoconfiguration中的以下部分可以发现:

?
1
2
3
4
5
6
7
8
9
@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 {
 
    }

有引入datasourceconfiguration.hikari.class这个默认类,点击进入,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@configuration(proxybeanmethods = false)
    @conditionalonclass(hikaridatasource.class)
    @conditionalonmissingbean(datasource.class)
    @conditionalonproperty(name = "spring.datasource.type", havingvalue = "com.zaxxer.hikari.hikaridatasource",
            matchifmissing = true)
    static class hikari {
 
        @bean
        @configurationproperties(prefix = "spring.datasource.hikari"
        hikaridatasource datasource(datasourceproperties properties) {
            hikaridatasource datasource = createdatasource(properties, hikaridatasource.class);
            if (stringutils.hastext(properties.getname())) {
                datasource.setpoolname(properties.getname());
            }
            return datasource;
        }
 
    }

由上述代码可以发现,默认的配置源是hikaridatasource,但是有一个要求:

@conditionalonmissingbean(datasource.class)

就是如果在容器中没有数据源,下面代码生效,也就是使用hikaridatasource,但是若容器中已经有开发者创建的数据源,那么开发者创建的优先。

在使用数据源的时候,不可避免地需要配置基本的属性,如:url、用户名、密码、端口号等。所以我们可以将这些信息抽取出来,放到配置文件中,

这里我们采用yaml写法application.yaml:

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

使用configurationproperties注解来进行属性的绑定:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
package com.xbhog.config;
 
import com.alibaba.druid.pool.druiddatasource;
import org.springframework.boot.context.properties.configurationproperties;
import org.springframework.context.annotation.bean;
import org.springframework.context.annotation.configuration;
 
import javax.sql.datasource;
 
@configuration
//配置数据源
public class mydtasourceconfig {
    @configurationproperties("spring.datasource"//属性绑定 要加对位置
    @bean
    public datasource datasource() {
        druiddatasource druiddatasource = new druiddatasource();
 
        return druiddatasource;
    }
}

进行单元测试:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
package com.xbhog;
 
import lombok.extern.slf4j.slf4j;
import org.junit.jupiter.api.test;
import org.springframework.beans.factory.annotation.autowired;
import org.springframework.boot.test.context.springboottest;
import org.springframework.jdbc.core.jdbctemplate;
 
import javax.sql.datasource;
 
@springboottest
@slf4j
class firstadminapplicationtests {
    @autowired
    datasource datasource;
    
    @test
    void contextloads() {
        log.info("数据类型:{}",datasource.getclass());
    }
}

结果==> 数据类型:class com.alibaba.druid.pool.druiddatasource

具体的配置绑定:个人博客

druid中的其他功能

配置监控页:

贴心文档链接:网页地址

SpringBoot数据访问自定义使用Druid数据源的方法

我们需要配置一个servlet配置,然后放到容器中,输入账号密码,进入链接地址即可访问;

在配置数据源代码下:

?
1
2
3
4
5
6
7
8
9
10
11
12
/**
* 配置监控页
*/
@bean
public servletregistrationbean staviewservlet(){
    //实例化statviewservlet
    statviewservlet statviewservlet = new statviewservlet();
     //将实例化的实例化statviewservlet 传入servletregistrationbean,并设置访问路径
    servletregistrationbean<statviewservlet> registrationbean = new servletregistrationbean<>(statviewservlet, "/druid/*");
 
    return registrationbean;
}

结果:

SpringBoot数据访问自定义使用Druid数据源的方法

开启登录功能:

因为登录设置还是在servlet中设置的,所以相关信息暂略,贴一个文档截图:

SpringBoot数据访问自定义使用Druid数据源的方法

代码添加:

?
1
2
3
4
5
6
7
8
9
10
@bean
public servletregistrationbean staviewservlet(){
    statviewservlet statviewservlet = new statviewservlet();
 
    servletregistrationbean<statviewservlet> registrationbean = new servletregistrationbean<>(statviewservlet, "/druid/*");
    //配置登录信息
    registrationbean.addinitparameter("loginusername","admin");
    registrationbean.addinitparameter("loginpassword","123456");
    return registrationbean;
}

结果:

SpringBoot数据访问自定义使用Druid数据源的方法

打开监控统计功能:

测试sql监控功能。

网页地址:

SpringBoot数据访问自定义使用Druid数据源的方法

创建一个druiddatasource组件,并配置其中的属性filters的value为stat,这样才能打开监控功能。

所以我们在创建数据源的地方需要配置filters属性:

?
1
2
3
4
5
6
7
8
9
10
public class mydtasourceconfig {
    @configurationproperties("spring.datasource")
    @bean
    public datasource datasource() throws sqlexception {
        druiddatasource druiddatasource = new druiddatasource();
        //加入监控功能
        druiddatasource.setfilters("stat");
        return druiddatasource;
    }
}

也可以进行属性的配置来实现上述的效果:(第二种方法)

?
1
2
3
4
5
6
7
8
9
10
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/vuesite
    username: root
    password: 123456
    driver-class-name: com.mysql.jdbc.driver
 
    filters: stat
    tomcat:
      max-active: 12

然后设置一个请求,来测试监控功能;

创建一个controller:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@controller
public class tablecontro {
 
      @autowired
    jdbctemplate jdbctemplate;
 
    @responsebody   //不经过视图解析器
    @getmapping("/sql")
    public string druidquery(){
        long along = jdbctemplate.queryforobject("select count(*) from user",long.class);
        return along.tostring();
    }
}

先访问localhost:8080/sql,然后进入http://localhost:8080/druid/index.html页面中的sql监控,即可查看执行次数次数。

SpringBoot数据访问自定义使用Druid数据源的方法

在最大并发的后面的有各种分布,可以参考官方文档:druid连接池介绍

开启web应用功能:

基本上还是跟上面一样的;

webstatfilter用于采集web-jdbc关联监控的数据。

网页地址

SpringBoot数据访问自定义使用Druid数据源的方法

配置一个webstatfilter,然后需要初始化exclusions,来排除一些不必要的url.得先进行sql的请求

?
1
2
3
4
5
6
7
8
9
10
11
12
/**
     * webstatfilter用于采集web-jdbc关联监控的数据。
     */
@bean
public filterregistrationbean webregistrationbean(){
    webstatfilter webstatfilter = new webstatfilter();
    filterregistrationbean<webstatfilter> registrationbean = new filterregistrationbean<>(webstatfilter);
    registrationbean.seturlpatterns(arrays.aslist("/*"));
    //添加一些不必要的ulr,在初始化的时候就执行
    registrationbean.addinitparameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
    return  registrationbean;
}

结果:

web应用:

SpringBoot数据访问自定义使用Druid数据源的方法

url监控

SpringBoot数据访问自定义使用Druid数据源的方法

配置防火墙:

wallfilter

SpringBoot数据访问自定义使用Druid数据源的方法

所以我们可以结合filter一起使用,代码如下:得先进行sql的请求。

?
1
2
3
4
5
6
7
8
9
10
public class mydtasourceconfig {
    @configurationproperties("spring.datasource")
    @bean
    public datasource datasource() throws sqlexception {
        druiddatasource druiddatasource = new druiddatasource();
        //加入监控功能
        druiddatasource.setfilters("stat,wall");
        return druiddatasource;
    }
}

结果:

SpringBoot数据访问自定义使用Druid数据源的方法

参考文献

Druid官方github地址

Druid中文文档

引用

SpringBoot2零基础入门springboot全套完整版

结束:

如果你看到这里或者正好对你有所帮助,希望能点个关注或者推荐,感谢;

有错误的地方,欢迎在评论指出,作者看到会进行修改。

到此这篇关于springboot数据访问自定义使用druid数据源的方法的文章就介绍到这了,更多相关springboot数据访问使用druid数据源内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/xbhog/p/15108549.html

延伸 · 阅读

精彩推荐
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06