亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot在yml配置文件中配置druid的操作

 更新時(shí)間:2020年11月16日 14:46:23   作者:JAdroid  
這篇文章主要介紹了SpringBoot在yml配置文件中配置druid的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

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

spring:
 ##數(shù)據(jù)庫(kù)連接信息
 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
 # 下面為連接池的補(bǔ)充設(shè)置,應(yīng)用到上面所有數(shù)據(jù)源中
 # 初始化大小,最小,最大
 initialSize: 5
 minIdle: 5
 maxActive: 20
 # 配置獲取連接等待超時(shí)的時(shí)間
 maxWait: 60000
 # 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒
 timeBetweenEvictionRunsMillis: 60000
 # 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒
 minEvictableIdleTimeMillis: 300000
 validationQuery: SELECT 1 FROM DUAL
 testWhileIdle: true
 testOnBorrow: false
 testOnReturn: false
 # 打開(kāi)PSCache,并且指定每個(gè)連接上PSCache的大小
 poolPreparedStatements: true
 maxPoolPreparedStatementPerConnectionSize: 20
 # 配置監(jiān)控統(tǒng)計(jì)攔截的filters,去掉后監(jiān)控界面sql無(wú)法統(tǒng)計(jì),'wall'用于防火墻
 filters: stat,wall,log4j
 # 通過(guò)connectProperties屬性來(lái)打開(kāi)mergeSql功能;慢SQL記錄
 connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
 # 合并多個(gè)DruidDataSource的監(jiān)控?cái)?shù)據(jù)
 useGlobalDataSourceStat: true
 ###############以上為配置druid添加的配置###########################

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

spring:
 ##數(shù)據(jù)庫(kù)連接信息
 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
 # 下面為連接池的補(bǔ)充設(shè)置,應(yīng)用到上面所有數(shù)據(jù)源中
 # 初始化大小,最小,最大
 initialSize: 5
 minIdle: 5
 maxActive: 20
 # 配置獲取連接等待超時(shí)的時(shí)間
 maxWait: 60000
 # 配置間隔多久才進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接,單位是毫秒
 timeBetweenEvictionRunsMillis: 60000
 # 配置一個(gè)連接在池中最小生存的時(shí)間,單位是毫秒
 minEvictableIdleTimeMillis: 300000
 validationQuery: SELECT 1 FROM DUAL
 testWhileIdle: true
 testOnBorrow: false
 testOnReturn: false
 # 打開(kāi)PSCache,并且指定每個(gè)連接上PSCache的大小
 poolPreparedStatements: true
 maxPoolPreparedStatementPerConnectionSize: 20
 # 配置監(jiān)控統(tǒng)計(jì)攔截的filters,去掉后監(jiān)控界面sql無(wú)法統(tǒng)計(jì),'wall'用于防火墻,此處是filter修改的地方
 filters:
  commons-log.connection-logger-name: stat,wall,log4j
 # 通過(guò)connectProperties屬性來(lái)打開(kāi)mergeSql功能;慢SQL記錄
 connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
 # 合并多個(gè)DruidDataSource的監(jiān)控?cái)?shù)據(jù)
 useGlobalDataSourceStat: true

順便附一下出現(xiàn)在springboot中yml配置文件里面配置druid的filter配置錯(cuò)誤的信息:

Property: spring.datasource.filters

Value: stat,wall,log4j

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

Reason: Unable to set value for property filters

補(bǔ)充知識(shí):Springboot中yml文件讀取

SpringBoot的.yml文件是一個(gè)非常簡(jiǎn)潔明了的配置文件,可看作.properties的精簡(jiǎn)版。

一般來(lái)講,我們通過(guò)@Value這個(gè)注解就可以直接獲取到某個(gè)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

一般來(lái)講,直接通過(guò)@Value(spring.datasource.druid.localhost.driverClassName)直接獲取到這個(gè)值了。

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

簡(jiǎn)單示例

SpringBoot中還有一種非常強(qiáng)大的注解@ConfigurationProperties,使用該注解可直接將yml的配置直接注入到某個(gè)對(duì)象中。

如:yml中有如下配置:

  info:
   user:
    name: zhangsan
    age: 14

這時(shí),我們定義個(gè)User對(duì)象:

class User{
 String name;
 int age;
 
//getter 及 setter方法 
}

在Spring容器中直接通過(guò)@ConfigurationProperties來(lái)注入,需要指定前綴到配置文件中user的上一層。對(duì)象名必須同yml中的配置。

@Component
@PropertySource("classpath:application-druid.yml") //指定yml文件位置
@ConfigurationProperties(prefix = "info")
public class YmlConfig{
 
 User user = new User();
//user getter及setter方法
}

Spring容器啟動(dòng)后,yml中的配置的屬性即注入到user對(duì)象。

或者我們也可以用個(gè)Map來(lái)進(jìn)行封裝,配置文件中的屬性無(wú)非就是key:value的形式,同樣定義user對(duì)象:

@Component
@PropertySource("classpath:application-druid.yml") //指定yml文件位置
@ConfigurationProperties(prefix = "info")  
public class YmlConfig{
 
 Map<String,String> user = new HashMap<>();
//user getter及setter方法
}

同樣也能注入到user的Map對(duì)象。

指定任意層

如本文開(kāi)始的那個(gè)yml配置文件的配置,如果,我想直接獲取到所有的數(shù)據(jù)源的配置,那么就必須要指定一個(gè)對(duì)象能裝下所有的這些配置,可以自定義對(duì)象,或者直接使用Map。如,我們定義如下的Map:

@Component
@ConfigurationProperties(prefix = "spring.datasource")
public class YmlConfig{
 
 Map<String,Map<String,String>> druid = new HashMap<>();
//user getter及setter方法
}

Spring容器其中后,配置文件中spring.datasource.druid以下的配置屬性同樣能注入到druid對(duì)象中去。

同樣指定其他層的配置,只要符合某個(gè)對(duì)象的數(shù)據(jù)結(jié)構(gòu),就能將配置的屬性注入到該對(duì)象中去。

以上這篇SpringBoot在yml配置文件中配置druid的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue.js通過(guò)路由實(shí)現(xiàn)經(jīng)典的三欄布局實(shí)例代碼

    vue.js通過(guò)路由實(shí)現(xiàn)經(jīng)典的三欄布局實(shí)例代碼

    本文通過(guò)實(shí)例代碼給大家介紹了vue.js通過(guò)路由實(shí)現(xiàn)經(jīng)典的三欄布局,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-07-07
  • apache和nginx下vue頁(yè)面刷新404的解決方案

    apache和nginx下vue頁(yè)面刷新404的解決方案

    這篇文章主要介紹了apache和nginx下vue頁(yè)面刷新404的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue項(xiàng)目中components組件(模板)的使用及說(shuō)明

    Vue項(xiàng)目中components組件(模板)的使用及說(shuō)明

    這篇文章主要介紹了Vue項(xiàng)目中components組件(模板)的使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue-cli構(gòu)建的項(xiàng)目如何手動(dòng)添加eslint配置

    vue-cli構(gòu)建的項(xiàng)目如何手動(dòng)添加eslint配置

    這篇文章主要介紹了vue-cli構(gòu)建的項(xiàng)目如何手動(dòng)添加eslint配置,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 通用vue組件化登錄頁(yè)面實(shí)例代碼

    通用vue組件化登錄頁(yè)面實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于通用vue組件化登錄頁(yè)面的相關(guān)資料,文中通過(guò)圖文以及實(shí)例代碼將解決的辦法介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-08-08
  • vue實(shí)現(xiàn)頁(yè)面切換滑動(dòng)效果

    vue實(shí)現(xiàn)頁(yè)面切換滑動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)頁(yè)面切換滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 如何利用vue.js實(shí)現(xiàn)拖放功能

    如何利用vue.js實(shí)現(xiàn)拖放功能

    這篇文章主要給大家介紹了如何利用vue.js實(shí)現(xiàn)拖放功能的相關(guān)資料,本文并未使用現(xiàn)有的庫(kù),而是使用內(nèi)置的HTML拖放API來(lái)實(shí)現(xiàn)簡(jiǎn)單的拖放系統(tǒng),需要的朋友可以參考下
    2021-06-06
  • 簡(jiǎn)單了解vue 插值表達(dá)式Mustache

    簡(jiǎn)單了解vue 插值表達(dá)式Mustache

    這篇文章主要介紹了vue 插值表達(dá)式Mustache的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • 如何使用ant-design-vue的Table組件

    如何使用ant-design-vue的Table組件

    這篇文章主要介紹了如何使用ant-design-vue的Table組件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue配置代理(devServer)解決跨域問(wèn)題

    Vue配置代理(devServer)解決跨域問(wèn)題

    這篇文章主要介紹了Vue配置代理(devServer)解決跨域問(wèn)題,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-08-08

最新評(píng)論