亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot學習(五)—— springboot快速整合Druid

發布時間:2020-06-14 17:54:23 來源:網絡 閱讀:844 作者:lgx211 欄目:軟件技術

Druid連接池

簡介

由阿里巴巴開源的druid連接池是目前綜合實力最突出的數據庫連接池,而且還提供了監控日志功能,能夠分析SQL執行情況。

引入druid連接池

pom.xml中加入

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

application.properties中加入

# druid
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

# 連接池初始化大小,最小,最大
spring.datasource.initialSize=10
spring.datasource.minIdle=10
spring.datasource.maxActive=30
# 連接等待超時時間
spring.datasource.maxWait=60000
# 多久檢測需要關閉的空閑連接
spring.datasource.timeBetweenEvictionRunsMillis=60000
# 一個連接在池中最小生存的時間
spring.datasource.minEvictableIdleTimeMillis=300000
# 校驗SQL,Oracle配置 spring.datasource.validationQuery=SELECT 1 FROM DUAL,如果不配validationQuery項,則下面三項配置無用
spring.datasource.validationQuery=SELECT 'x'
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
# 打開PSCache,并且指定每個連接上PSCache的大小
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置監控統計攔截的filters,去掉后監控界面sql無法統計,wall用于防火墻
spring.datasource.filters=stat,wall,log4j
# 通過connectProperties屬性來打開mergeSql功能;慢SQL記錄
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
# 合并多個DruidDataSource的監控數據
spring.datasource.useGlobalDataSourceStat=true

注:之前已經配置好了mysql,mybatis,這里沒有重復寫了

代碼實戰

新增了一個DruidFilter.java來配置內置的監控

SpringBoot學習(五)—— springboot快速整合Druid
DruidFilter.java

package com.example.config;

import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
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;

@Configuration
public class DruidFilter {

    @Bean
    public ServletRegistrationBean druidStatView() {
        //指定路徑進入內置監控頁面
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*");

        //IP白名單:
        servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
        //IP黑名單
        servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
        //登錄查看信息的賬號密碼.
        //servletRegistrationBean.addInitParameter("loginUsername", "admin");
        //servletRegistrationBean.addInitParameter("loginPassword", "123456");
        //是否能夠重置數據.
        servletRegistrationBean.addInitParameter("resetEnable", "true");
        return servletRegistrationBean;
    }

    @Bean
    public FilterRegistrationBean druidWebStatFilter() {
        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
        //添加過濾規則.
        filterRegistrationBean.addUrlPatterns("/*");
        //添加不需要忽略的格式信息.
        filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
        return filterRegistrationBean;
    }

}

注:我之前就已經配置好了spring security,如果在和其他教程一樣配置druid的賬號密碼,會導致輸入druid的賬號密碼后無法跳轉進入內置監控頁面,我知道有很多方法可以避免,但那都需要額外增加代碼來判斷繞過,既然spring security已經有了賬號權限,何必額外非得給druid單獨增加一套賬號權限,把 /druid/* 路徑配置在spring security中,公用已有的賬號權限不更好嘛。所以我沒有單獨配置。

還有這只是常用的配置,如若需要進一步了解詳細的配置

內置監控頁面配置詳情,Web關聯配置詳情

效果圖如下

SpringBoot學習(五)—— springboot快速整合Druid
恩恩,還自帶阿里云的廣告,果然是阿里的開源產品

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

扎鲁特旗| 山阳县| 光泽县| 普安县| 深圳市| 郴州市| 萍乡市| 尚义县| 和平县| 会宁县| 宜城市| 汉中市| 黑龙江省| 乐山市| 介休市| 义马市| 融水| 苏尼特左旗| 招远市| 梅州市| 六盘水市| 都兰县| 丘北县| 马关县| 阳新县| 新宁县| 阜南县| 宁安市| 晋中市| 左贡县| 瑞安市| 永吉县| 酉阳| 隆昌县| 凤台县| 香格里拉县| 焉耆| 吴忠市| 平邑县| 彭水| 邢台市|