https://blog.csdn.net/wangmx1993328/article/details/81865153

springboot 使用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");

最新文章

  1. 手把手教你用Python抓取AWS的日志(CloudTrail)数据
  2. String之-如何取得精确byte长度字符串
  3. [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序处理并发
  4. [推荐]DataX、DbSync和Timetunnel学习贴
  5. eq相等 ,ne、neq不相等 EL表达式
  6. rand.Read() 和 io.ReadFull(rand.Reader) 的区别?
  7. Helpers\RainCaptcha
  8. mysql常用的一些命令,用于查看数据库、表、字段编码
  9. node.js + mongodb
  10. js实现浏览器通知功能
  11. swift -- 静态变量static
  12. PHP通过Zabbix API获取服务器监控信息
  13. 【CSS3】浏览器内核、私有前缀
  14. [bzoj3910] 火车
  15. ubuntu中gdb调试工具的使用
  16. linq用法整理
  17. jQuery实现的3个基础案例(仿QQ列表分组,二级联动下拉框,模拟员工信息管理系统)
  18. Java Map在遍历过程中删除元素
  19. win10+cpu+tensorflow+pycharm
  20. es6基础(4)--字符串扩展

热门文章

  1. 06 Vue生命周期钩子
  2. java8的parallelStream提升数倍查询效率
  3. 爬虫页面解析 lxml 简单教程
  4. SQLAlchemy(四):SQLAlchemy查询高级
  5. 数据可视化之PowerQuery篇(五)PowerQuery文本处理技巧:移除和提取
  6. Java应用服务器之tomcat基础配置(一)
  7. DEX文件解析--6、dex文件字段和方法定义解析
  8. [Qt2D绘图]-03坐标系统之坐标变换
  9. Ethical Hacking - NETWORK PENETRATION TESTING(22)
  10. X-Tag实战:给博客加一个隐藏侧栏的功能