druid mysql yml_SpringBoot在yml配置文件中配置druid的操作

最新版的druid和旧版在filter配置方面有些不同,以下是旧版druid中配置filter:

spring:

##数据库连接信息

datasource:

url: jdbc:mysql://localhost:3306/young

username: root

password: root

driver-class-name: com.mysql.jdbc.Driver

###################以下为druid增加的配置###########################

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

# 打开PSCache,并且指定每个连接上PSCache的大小

poolPreparedStatements: true

maxPoolPreparedStatementPerConnectionSize: 20

# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙

filters: stat,wall,log4j

# 通过connectProperties属性来打开mergeSql功能;慢SQL记录

connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

# 合并多个DruidDataSource的监控数据

useGlobalDataSourceStat: true

###############以上为配置druid添加的配置###########################

下面是1.1.10版本的druid配置filter:

spring:

##数据库连接信息

datasource:

url: jdbc:mysql://localhost:3306/day05

username: root

password: 15963asd

driver-class-name: com.mysql.jdbc.Driver

###################以下为druid增加的配置###########################

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

# 打开PSCache,并且指定每个连接上PSCache的大小

poolPreparedStatements: true

maxPoolPreparedStatementPerConnectionSize: 20

# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙,此处是filter修改的地方

filters:

commons-log.connection-logger-name: stat,wall,log4j

# 通过connectProperties属性来打开mergeSql功能;慢SQL记录

connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

# 合并多个DruidDataSource的监控数据

useGlobalDataSourceStat: true

顺便附一下出现在springboot中yml配置文件里面配置druid的filter配置错误的信息:

Property: spring.datasource.filters

Value: stat,wall,log4j

Origin: class path resource [application.yml]:29:14

Reason: Unable to set value for property filters

补充知识:Springboot中yml文件读取

SpringBoot的.yml文件是一个非常简洁明了的配置文件,可看作.properties的精简版。

一般来讲,我们通过@Value这个注解就可以直接获取到某个properties的值。

如:有如下配置:

spring:

datasource:

druid:

localhost:

driverClassName: com.mysql.jdbc.Driver

url: jdbc:mysql://localhost:3306/paas-dashboard?useUnicode=true&characterEncoding=utf8

username: root

password:123

master:

driverClassName: oracle.jdbc.OracleDriver

url: jdbc:oracle:thin:@//172.21.0.73:1621/tthradb

username: dbchnesbcfgcha

password: dbchnesbcfgcha

一般来讲,直接通过@Value(spring.datasource.druid.localhost.driverClassName)直接获取到这个值了。

但是如果需要直接获取到localhost下面所有的配置呢?或者自己指定某一层下面所有的配置信息呢?

简单示例

SpringBoot中还有一种非常强大的注解@ConfigurationProperties,使用该注解可直接将yml的配置直接注入到某个对象中。

如:yml中有如下配置:

info:

user:

name: zhangsan

age: 14

这时,我们定义个User对象:

class User{

String name;

int age;

//getter 及 setter方法

}

在Spring容器中直接通过@ConfigurationProperties来注入,需要指定前缀到配置文件中user的上一层。对象名必须同yml中的配置。

@Component

@PropertySource("classpath:application-druid.yml") //指定yml文件位置

@ConfigurationProperties(prefix = "info")

public class YmlConfig{

User user = new User();

//user getter及setter方法

}

Spring容器启动后,yml中的配置的属性即注入到user对象。

或者我们也可以用个Map来进行封装,配置文件中的属性无非就是key:value的形式,同样定义user对象:

@Component

@PropertySource("classpath:application-druid.yml") //指定yml文件位置

@ConfigurationProperties(prefix = "info")

public class YmlConfig{

Map user = new HashMap<>();

//user getter及setter方法

}

同样也能注入到user的Map对象。

指定任意层

如本文开始的那个yml配置文件的配置,如果,我想直接获取到所有的数据源的配置,那么就必须要指定一个对象能装下所有的这些配置,可以自定义对象,或者直接使用Map。如,我们定义如下的Map:

@Component

@ConfigurationProperties(prefix = "spring.datasource")

public class YmlConfig{

Map> druid = new HashMap<>();

//user getter及setter方法

}

Spring容器其中后,配置文件中spring.datasource.druid以下的配置属性同样能注入到druid对象中去。

同样指定其他层的配置,只要符合某个对象的数据结构,就能将配置的属性注入到该对象中去。

以上这篇SpringBoot在yml配置文件中配置druid的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

本文标题: SpringBoot在yml配置文件中配置druid的操作

本文地址: http://www.cppcns.com/wangluo/javascript/364562.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DruidYML文件需要配置的内容包括: 1. 数据源配置: 包括数据库连接信息、查询SQL语句等。 2. 索引配置: 包括索引类型、分片数量等。 3. 任务配置: 包括定时任务、手动任务等。 4. 其他配置: 包括集群配置、服务器配置等。 具体配置方式可以参考Druid官方文档。 ### 回答2: Druid是一种开源的数据库连接池,可以用于管理和优化数据库连接的使用。在yml文件进行Druid配置可以实现对Druid连接池的定制和优化。 首先,我们需要在yml文件添加Druid连接池的配置信息。可以使用以下配置项: ``` spring: datasource: type: com.alibaba.druid.pool.DruidDataSource url: jdbc:mysql://localhost:3306/mydb username: root password: password driver-class-name: com.mysql.jdbc.Driver ``` 在上面的配置,我们指定了数据库的url、用户名、密码和驱动程序。这些配置项可以根据实际情况进行修改。 接下来,我们可以设置Druid连接池的一些参数,以优化连接池的性能。以下是一些常用的配置项: ``` druid: initial-size: 5 min-idle: 5 max-active: 20 max-wait: 60000 time-between-eviction-runs-millis: 60000 min-evictable-idle-time-millis: 300000 validation-query: SELECT 1 test-while-idle: true test-on-borrow: false test-on-return: false pool-prepared-statements: true max-pool-prepared-statement-per-connection-size: 20 filters: stat,wall ``` 在上面的配置,我们设置了连接池的初始大小、最小空闲连接数、最大活跃连接数、最长等待时间等参数。还可以设置连接保持存活的时间、连接验证查询、是否在连接池空闲时进行连接测试等。同时,我们也可以通过配置过滤器来收集连接池的统计信息和实施SQL防火墙。 以上是在yml文件配置Druid连接池的一些常用配置项。根据实际需求和具体情况,可以进行进一步定制和优化。配置完成后,Druid连接池将按照我们的配置进行连接管理和优化,提高数据库的性能和稳定性。 ### 回答3: 在yml文件,我们可以使用Druid进行数据库连接池的配置。首先,我们需要添加相关的Druid依赖包。在yml文件,可以通过以下方式进行Druid配置: 1. 配置数据源: ```yaml spring: datasource: url: jdbc:mysql://localhost:3306/test # 数据库连接地址 username: root # 数据库用户名 password: password # 数据库密码 driver-class-name: com.mysql.jdbc.Driver # 数据库驱动类名 type: com.alibaba.druid.pool.DruidDataSource # 数据源类型为Druid ``` 2. 配置Druid连接池参数: ```yaml spring: datasource: initialSize: 5 # 初始化连接数 minIdle: 5 # 最小空闲连接数 maxActive: 20 # 最大连接数 maxWait: 60000 # 最大等待时间,单位毫秒 timeBetweenEvictionRunsMillis: 60000 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位毫秒 minEvictableIdleTimeMillis: 300000 # 一个连接在池最小生存的时间,单位毫秒 validationQuery: SELECT 1 FROM DUAL # 用来验证连接是否有效的SQL testWhileIdle: true # 连接空闲时是否执行验证 testOnBorrow: false # 从连接池借用连接时是否执行验证 testOnReturn: false # 归还连接到连接池时是否执行验证 poolPreparedStatements: true # 是否开启PSCache maxPoolPreparedStatementPerConnectionSize: 20 # 每个连接上PSCache的大小 ``` 3. 配置Druid监控页面: ```yaml spring: druid: stat-view-servlet: enabled: true # 开启Druid监控页面 login-username: admin # 监控页面登录用户名 login-password: password # 监控页面登录密码 filter: stat: enabled: true # 开启Druid的StatFilter web: enabled: true # 开启Druid的WebStatFilter exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*" # 忽略的资源 ``` 以上是在yml文件配置Druid的一些常用参数,通过这些参数可以自定义Druid的连接池属性和监控页面属性。这样我们就可以通过配置文件来管理和控制Druid连接池的行为和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值