Spring Boot 自定义数据源DruidDataSource代码

所属分类: 软件编程 / java 阅读数: 36
收藏 0 赞 0 分享

这篇文章主要介绍了Spring Boot 自定义数据源DruidDataSource代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一、添加依赖

  <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.0.26</version>
  </dependency>

二、配置application.yml

spring:
  datasource:
url: jdbc:mysql://127.0.0.1:3306/mxntest?characterEncoding=UTF-8
username: root
password: root
driver-class-name: com.mysql.jdbc.Driver
type: com.alibaba.druid.pool.DruidDataSource
# 初始化大小,最小,最大
initialSize: 5
minIdle: 5
maxActive: 50
# 配置获取连接等待超时的时间
maxWait: 60000

三、Druid数据源配置

package com.example.demo.config;

/**
 * @author 12084
 * @create 2018-08-09 11:27
 */

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;

import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

/**
 * Druid数据源配置
 */
@Configuration
public class DataSourceConfig {

private static String dbUrl;

private static String username;

private static String password;

private static String driverClassName;

private static int initialSize;

private static int minIdle;

private static int maxActive;

private static int maxWait;

/**
 * 注册DruidServlet
 *
 * @return
 */
@Bean
public ServletRegistrationBean druidServletRegistrationBean() {
  ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean();
  servletRegistrationBean.setServlet(new StatViewServlet());
  servletRegistrationBean.addUrlMappings("/druid/*");
  //登录查看信息的账号密码.
  servletRegistrationBean.addInitParameter("loginUsername", "admin");
  servletRegistrationBean.addInitParameter("loginPassword", "123456");
  return servletRegistrationBean;
}

/**
 * 注册DruidFilter拦截
 *
 * @return
 */
@Bean
public FilterRegistrationBean druidFilterRegistrationBean() {
  FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
  filterRegistrationBean.setFilter(new WebStatFilter());
  Map<String, String> initParams = new HashMap<String, String>();
  //设置忽略请求
  initParams.put("exclusions", "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*");
  filterRegistrationBean.setInitParameters(initParams);
  filterRegistrationBean.addUrlPatterns("/*");
  return filterRegistrationBean;
}

/**
 * 配置DataSource
 * @return
 * @throws SQLException
 */
@Bean(initMethod = "init",destroyMethod = "close")
@Primary
public DataSource dataSource() throws SQLException {
  DruidDataSource druidDataSource = new DruidDataSource();
  druidDataSource.setUsername(username);
  druidDataSource.setPassword(password);
  druidDataSource.setUrl(dbUrl);
  druidDataSource.setFilters("stat,wall");
  druidDataSource.setInitialSize(initialSize);
  druidDataSource.setMinIdle(minIdle);
  druidDataSource.setMaxActive(maxActive);
  druidDataSource.setMaxWait(maxWait);
  druidDataSource.setUseGlobalDataSourceStat(true);
  druidDataSource.setDriverClassName(driverClassName);
  return druidDataSource;
}

@Value("${spring.datasource.url}")
public void setDbUrl(String dbUrl) {
  DataSourceConfig.dbUrl = dbUrl;
}

@Value("${spring.datasource.username}")
public void setUsername(String username) {
  DataSourceConfig.username = username;
}

@Value("${spring.datasource.password}")
public void setPassword(String password) {
  DataSourceConfig.password = password;
}

@Value("${spring.datasource.driver-class-name}")
public void setDriverClassName(String driverClassName) {
  DataSourceConfig.driverClassName = driverClassName;
}

@Value(value = "${spring.datasource.initialSize}")
public void setInitialSize(int initialSize) {
  DataSourceConfig.initialSize = initialSize;
}

@Value(value = "${spring.datasource.minIdle}")
public void setMinIdle(int minIdle) {
  DataSourceConfig.minIdle = minIdle;
}

@Value(value = "${spring.datasource.maxActive}")
public void setMaxActive(int maxActive) {
  DataSourceConfig.maxActive = maxActive;
}

@Value(value = "${spring.datasource.maxWait}")
public void setMaxWait(int maxWait) {
  DataSourceConfig.maxWait = maxWait;
}

}

四、http://localhost:8080/druid/index.html 就可以查看,如果配置密码则输入密码

  //登录查看信息的账号密码.
  servletRegistrationBean.addInitParameter("loginUsername", "admin");
  servletRegistrationBean.addInitParameter("loginPassword", "123456");

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Springmvc restful配置遇到的小坑

本文是小编给大家带了的Springmvc restful配置遇到的小小坑,小编给大家带来了问题原因及解决办法,非常不错,具有参考借鉴价值,感兴趣的朋友一起看下吧
收藏 0 赞 0 分享

Java中的匿名内部类小结

java内部类分为: 成员内部类、静态嵌套类、方法内部类、匿名内部类。这篇文章主要介绍了Java中的匿名内部类的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java的云打印Lodop

这篇文章主要介绍了Java的云打印Lodop 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Java线程池框架核心代码解析

这篇文章主要针对Java线程池框架核心代码进行详细解析,分析Java线程池框架的实现ThreadPoolExecutor,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Java 交换两个变量的数值实现方法

下面小编就为大家带来一篇Java 交换两个变量的数值实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

全面了解JAVA_BaseDAO数据处理类

下面小编就为大家带来一篇全面了解JAVA_BaseDAO数据处理类。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

java、python、JavaScript以及jquery循环语句的区别

本篇文章主要介绍java、python、JavaScript以及jquery的循环语句的区别,这里整理了它们循环语句语法跟示例,以便大家阅读,更好的区分它们的不同
收藏 0 赞 0 分享

基于JDBC封装的BaseDao(实例代码)

下面小编就为大家带来一篇基于JDBC封装的BaseDao(实例代码)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

简单通用JDBC辅助类封装(实例)

下面小编就为大家带来一篇简单通用JDBC辅助类封装(实例)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

浅谈java线程中生产者与消费者的问题

下面小编就为大家带来一篇浅谈java线程中生产者与消费者的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多