欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot集成Druid監(jiān)控慢SQL的詳細(xì)過程

 更新時(shí)間:2024年06月21日 09:17:26   作者:奮斗的狍子007  
數(shù)據(jù)庫連接池是一個(gè)至關(guān)重要的組成部分,一個(gè)優(yōu)秀的數(shù)據(jù)庫連接池可以顯著提高應(yīng)用程序的性能和可伸縮性,常見的連接池:Druid、HikariCP、C3P0、DBCP等等,本文將詳細(xì)介紹如何在Spring Boot項(xiàng)目中配置數(shù)據(jù)源,集成Druid連接池,以實(shí)現(xiàn)更高效的數(shù)據(jù)庫連接管理

一、前言

數(shù)據(jù)庫連接池是一個(gè)至關(guān)重要的組成部分,一個(gè)優(yōu)秀的數(shù)據(jù)庫連接池可以顯著提高應(yīng)用程序的性能和可伸縮性。常見的連接池:Druid、HikariCP、C3P0、DBCP等等,不過目前大部分都是使用Druid或者SpringBoot默認(rèn)的HikariCP!

本文將詳細(xì)介紹如何在Spring Boot項(xiàng)目中配置數(shù)據(jù)源,集成Druid連接池,以實(shí)現(xiàn)更高效的數(shù)據(jù)庫連接管理。

二、常見的連接池介紹

1. C3P0

開源的JDBC連接池:C3P0實(shí)現(xiàn)了數(shù)據(jù)源和JNDI綁定,支持JDBC3規(guī)范和JDBC2的標(biāo)準(zhǔn)擴(kuò)展。

穩(wěn)定性好:盡管速度相對(duì)較慢(只是慢一丟丟),但穩(wěn)定性很好,Hibernate和Spring底層就使用了C3P0。

2. DBCP

Tomcat的數(shù)據(jù)庫連接池:Apache Tomcat DBCP是一個(gè)用于管理數(shù)據(jù)庫連接的組件,通常與Apache Tomcat服務(wù)器一起使用。

高效管理:它提供了一種機(jī)制來有效地管理數(shù)據(jù)庫連接,以便在高負(fù)載下提供更好的性能和可伸縮性。

配置靈活:可以通過Tomcat的配置文件(如context.xml)或者直接在應(yīng)用程序中的代碼中配置連接池的各種參數(shù)。

驗(yàn)證和性能優(yōu)化:DBCP可以配置為在從連接池中獲取連接時(shí)驗(yàn)證連接的有效性,并避免在每次數(shù)據(jù)庫請(qǐng)求時(shí)都重新創(chuàng)建和銷毀連接,從而提高了性能和效率。

3. HikariCP

高性能:HikariCP是一個(gè)高性能的Java數(shù)據(jù)庫連接池,它通過使用異步和非阻塞的方式,以及一些性能優(yōu)化的技術(shù),實(shí)現(xiàn)了卓越的連接獲取和釋放性能。

輕量級(jí):HikariCP的代碼庫非常小,只有幾百KB大小,不依賴大量的外部庫和復(fù)雜的依賴關(guān)系。

自動(dòng)化管理:HikariCP具有自動(dòng)化管理連接池的功能,可以根據(jù)應(yīng)用程序的需求動(dòng)態(tài)調(diào)整連接數(shù),并自動(dòng)管理連接的生命周期。

配置靈活:提供豐富的可配置選項(xiàng),支持連接池的最大連接數(shù)、最小空閑連接數(shù)、連接超時(shí)時(shí)間等多種配置參數(shù)。

4. Druid

高性能:Druid使用多線程和緩存技術(shù),能夠充分發(fā)揮數(shù)據(jù)庫的性能,提高應(yīng)用程序的響應(yīng)速度。

監(jiān)控功能:Druid提供了豐富的監(jiān)控功能,可以幫助開發(fā)人員及時(shí)發(fā)現(xiàn)和解決數(shù)據(jù)庫連接池的問題。

擴(kuò)展性強(qiáng):Druid具有良好的擴(kuò)展性,可以輕松地與其他框架集成,滿足不同應(yīng)用程序的需求。

防御能力:Druid具有強(qiáng)大的防御機(jī)制,可以有效地防止SQL注入等攻擊。

三、Druid介紹

Druid是一個(gè)由阿里巴巴開源的數(shù)據(jù)庫連接池實(shí)現(xiàn),它結(jié)合了C3P0、DBCP等數(shù)據(jù)庫連接池的優(yōu)點(diǎn),并加入了日志監(jiān)控功能。Druid支持所有JDBC兼容的數(shù)據(jù)庫,包括Oracle、MySql、Derby、Postgresql、SQL Server、H2等,并針對(duì)Oracle和MySql做了特別優(yōu)化。

Druid不僅是一個(gè)數(shù)據(jù)庫連接池,還提供了強(qiáng)大的監(jiān)控功能,可以監(jiān)控SQL的執(zhí)行時(shí)間、ResultSet持有時(shí)間、返回行數(shù)、更新行數(shù)等關(guān)鍵指標(biāo),有助于線上分析數(shù)據(jù)庫訪問性能

四、Druid的優(yōu)缺點(diǎn)

Druid的優(yōu)點(diǎn):

高性能:Druid能夠在高并發(fā)的環(huán)境下提供穩(wěn)定、快速的數(shù)據(jù)庫訪問服務(wù)。它使用內(nèi)存緩存、線程池、連接池等先進(jìn)技術(shù)來實(shí)現(xiàn)高性能,并且支持對(duì)SQL進(jìn)行解析和優(yōu)化,選擇最合適的執(zhí)行計(jì)劃,從而提高數(shù)據(jù)庫的執(zhí)行效率。

可擴(kuò)展性:Druid具有很好的可擴(kuò)展性,能夠根據(jù)業(yè)務(wù)的發(fā)展進(jìn)行靈活的擴(kuò)展。其設(shè)計(jì)采用了模塊化的思想,各個(gè)模塊之間解耦,方便進(jìn)行擴(kuò)展和升級(jí)。同時(shí),Druid還支持各種數(shù)據(jù)庫,可以在不同的數(shù)據(jù)庫之間進(jìn)行切換。

穩(wěn)定性:Druid具有很高的穩(wěn)定性,能夠在系統(tǒng)運(yùn)行過程中保持穩(wěn)定,不會(huì)出現(xiàn)大的波動(dòng)。它在內(nèi)部實(shí)現(xiàn)了自動(dòng)均衡和負(fù)載均衡的功能,能夠根據(jù)數(shù)據(jù)庫服務(wù)器的負(fù)載情況自動(dòng)調(diào)整負(fù)載,保持了系統(tǒng)的穩(wěn)定性。此外,Druid還具有完善的異常處理機(jī)制,能夠及時(shí)處理異常情況,避免對(duì)系統(tǒng)造成大的影響。

強(qiáng)大的監(jiān)控能力:Druid具有強(qiáng)大的監(jiān)控能力,能夠?qū)崟r(shí)監(jiān)控和統(tǒng)計(jì)系統(tǒng)的各項(xiàng)指標(biāo),如連接數(shù)、SQL執(zhí)行效率、系統(tǒng)負(fù)載等。此外,它還支持與第三方監(jiān)控系統(tǒng)進(jìn)行集成,方便進(jìn)行系統(tǒng)的監(jiān)控和管理。

豐富的功能:Druid具有豐富的功能,如支持對(duì)SQL語句進(jìn)行動(dòng)態(tài)配置、數(shù)據(jù)庫備份和恢復(fù)、分庫分表等功能,方便對(duì)數(shù)據(jù)進(jìn)行管理和訪問。

高可用性:Druid連接池支持對(duì)連接的有效性進(jìn)行檢測(cè),可以自動(dòng)剔除無效的連接,并重新創(chuàng)建新的連接來保證連接的可用性。這些檢測(cè)機(jī)制可以避免應(yīng)用程序使用無效的數(shù)據(jù)庫連接,提高了應(yīng)用程序的穩(wěn)定性和可靠性。

安全性:Druid連接池提供了多種安全特性,包括防止惡意代碼注入、SQL注入和XSS攻擊等。它還支持按照IP地址、用戶名和密碼等方式對(duì)連接進(jìn)行白名單和黑名單過濾,增強(qiáng)了數(shù)據(jù)庫連接的安全性。

配置靈活:Druid連接池具有豐富的配置選項(xiàng),可以靈活地配置連接池的參數(shù),以滿足不同應(yīng)用程序的需求。

Druid的缺點(diǎn):

依賴性:將Druid引入項(xiàng)目會(huì)增加項(xiàng)目的依賴,可能會(huì)影響構(gòu)建和部署的復(fù)雜性。

五、Springboot集成Druid

1. 添加依賴

<!-- druid數(shù)據(jù)源 -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.23</version>
</dependency>

<!-- mysql驅(qū)動(dòng)-->
<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
	<version>5.1.30</version>
</dependency>


<!--mybatis,引入了 SpringBoot的 JDBC 模塊,所以,默認(rèn)是使用 hikari 作為數(shù)據(jù)源-->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.0.0</version>
    <exclusions>
        <!-- 排除默認(rèn)的 HikariCP 數(shù)據(jù)源 -->
        <exclusion>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
        </exclusion>
    </exclusions>
</dependency>

2. 添加配置

# 數(shù)據(jù)庫連接配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/mysql?relaxAutoCommit=true&zeroDateTimeBehavior=convertToNull&characterEncoding=utf-8&useSSL=false
spring.datasource.username=root
spring.datasource.password=root

# 配置初始化大小、最小、最大
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=1
spring.datasource.druid.max-active=10

# 配置獲取連接等待超時(shí)的時(shí)間(單位:毫秒)
spring.datasource.druid.max-wait=60000

# 配置StatViewServlet(監(jiān)控頁面),用于展示Druid的統(tǒng)計(jì)信息
spring.datasource.druid.stat-view-servlet.enabled=true

# 訪問內(nèi)置監(jiān)控頁面的路徑,內(nèi)置監(jiān)控頁面的首頁是/druid/index.html
spring.datasource.druid.stat-view-servlet.url-pattern=/druid/*


# 監(jiān)控頁面賬戶與密碼
spring.datasource.druid.stat-view-servlet.login-username=admin
spring.datasource.druid.stat-view-servlet.login-password=admin

# 配置WebStatFilter,用于采集web關(guān)聯(lián)監(jiān)控的數(shù)據(jù)
spring.datasource.druid.web-stat-filter.enabled=true
spring.datasource.druid.web-stat-filter.url-pattern=/*
spring.datasource.druid.web-stat-filter.exclusions=*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*

# 開啟druiddatasource的狀態(tài)監(jiān)控
spring.datasource.druid.filter.stat.enabled=true
spring.datasource.druid.filter.stat.db-type=mysql

# 開啟慢sql監(jiān)控
spring.datasource.druid.filter.stat.log-slow-sql=true

# 超過500ms 就認(rèn)為是慢sql,記錄到日志中,為了測(cè)試我這邊設(shè)置的小一點(diǎn)
spring.datasource.druid.filter.stat.slow-sql-millis=2

# 也可以這樣子,不過這個(gè)使用的都是默認(rèn)配置了
spring.datasource.druid.filters=stat,wall

3. 啟動(dòng)項(xiàng)目后,訪問 /druid/index.html,輸入上面配置中的用戶名與密碼

在這里插入圖片描述

4. 去除廣告

進(jìn)來之后發(fā)現(xiàn)這里有個(gè)廣告。展示的不太友好啊。

在這里插入圖片描述

添加一個(gè)過濾器,把這里不需要顯示的js給過濾掉。

@Configuration
@ConditionalOnWebApplication
@AutoConfigureAfter(DruidDataSourceAutoConfigure.class)
@ConditionalOnProperty(name = "spring.datasource.druid.stat-view-servlet.enabled", havingValue = "true", matchIfMissing = true)
public class DruidAdConfig {

    @Bean
    public FilterRegistrationBean removeDruidAdFilterRegistrationBean(DruidStatProperties properties) {

        // 獲取web監(jiān)控頁面的參數(shù)
        DruidStatProperties.StatViewServlet config = properties.getStatViewServlet();
        // 提取common.js的配置路徑
        String pattern = config.getUrlPattern() != null ? config.getUrlPattern() : "/druid/*";
        String commonJsPattern = pattern.replaceAll("\\*", "js/common.js");

        final String filePath = "support/http/resources/js/common.js";

        //創(chuàng)建filter進(jìn)行過濾
        Filter filter = new Filter() {
            @Override
            public void init(FilterConfig filterConfig) throws ServletException {}

            @Override
            public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
                chain.doFilter(request, response);
                // 重置緩沖區(qū),響應(yīng)頭不會(huì)被重置
                response.resetBuffer();
                // 獲取common.js
                String text = Utils.readFromResource(filePath);
                // 正則替換banner, 除去底部的廣告信息
                text = text.replaceAll("<a.*?banner\"></a><br/>", "");
                text = text.replaceAll("powered.*?shrek.wang</a>", "");
                response.getWriter().write(text);
            }

            @Override
            public void destroy() {}
        };

        FilterRegistrationBean registrationBean = new FilterRegistrationBean();
        registrationBean.setFilter(filter);
        registrationBean.addUrlPatterns(commonJsPattern);
        return registrationBean;
    }
}

重新啟動(dòng)項(xiàng)目,重新登陸賬號(hào)進(jìn)入查看。

在這里插入圖片描述

5. SQL監(jiān)控頁面

執(zhí)行一些接口調(diào)用之后,在查看SQL監(jiān)控頁面。

在這里插入圖片描述

提供了慢SQL的統(tǒng)計(jì)信息,如慢SQL的數(shù)量、總執(zhí)行時(shí)間、執(zhí)行行數(shù)等。

六、獲取Druid的監(jiān)控?cái)?shù)據(jù)

Druid的監(jiān)控?cái)?shù)據(jù)可以在開啟StatFilter后 ,通過DruidStatManagerFacade進(jìn)行獲取。DruidStatManagerFacade#getDataSourceStatDataList該方法可以獲取所有數(shù)據(jù)源的監(jiān)控?cái)?shù)據(jù),除此之外 DruidStatManagerFacade 還提供了一些其他方法,可以按需選擇使用。

@RestController
@RequestMapping(value = "/druid")
public class DruidStatController {

    @GetMapping("/stat")
    public Object druidStat(){
        // 獲取數(shù)據(jù)源的監(jiān)控?cái)?shù)據(jù)
        return DruidStatManagerFacade.getInstance().getDataSourceStatDataList();
    }
}

在這里插入圖片描述

Druid是一個(gè)功能強(qiáng)大、性能優(yōu)異、易于使用、可擴(kuò)展和可靠的數(shù)據(jù)庫連接池。在實(shí)際應(yīng)用中,它已經(jīng)被廣泛應(yīng)用于各種高并發(fā)、大數(shù)據(jù)量和大批量請(qǐng)求的業(yè)務(wù)場(chǎng)景中,并得到了業(yè)界的廣泛認(rèn)可和好評(píng)。使用它可以幫我們創(chuàng)建和管理數(shù)據(jù)庫連接,可以使用慢sql等監(jiān)控功能,使用數(shù)據(jù)庫密碼加密等豐富的擴(kuò)展功能。

以上就是SpringBoot集成Druid監(jiān)控慢SQL的詳細(xì)過程的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Druid監(jiān)控慢SQL的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Feign如何實(shí)現(xiàn)第三方的HTTP請(qǐng)求

    Feign如何實(shí)現(xiàn)第三方的HTTP請(qǐng)求

    這篇文章主要介紹了Feign如何實(shí)現(xiàn)第三方的HTTP請(qǐng)求,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • java PDF添加圖層的方法 支持多頁圖層添加

    java PDF添加圖層的方法 支持多頁圖層添加

    這篇文章主要為大家詳細(xì)介紹了java PDF添加圖層的方法,支持多頁圖層添加,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • JavaFX如何獲取ListView(列表視圖)的選項(xiàng)

    JavaFX如何獲取ListView(列表視圖)的選項(xiàng)

    這篇文章主要介紹了JavaFX如何獲取ListView(列表視圖)的選項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • springboot 增加過濾器方法操作示例

    springboot 增加過濾器方法操作示例

    這篇文章主要介紹了springboot 增加過濾器方法操作,結(jié)合實(shí)例形式分析了springboot過濾器配置、加載等相關(guān)操作技巧,需要的朋友可以參考下
    2019-12-12
  • Lombok基本注解之@SneakyThrows的作用

    Lombok基本注解之@SneakyThrows的作用

    @SneakyThrows注解是由lombok為咱們封裝的,它能夠?yàn)樵蹅兊拇a生成一個(gè)try...catch塊,并把異常向上拋出來,下面這篇文章主要給大家介紹了關(guān)于Lombok基本注解之@SneakyThrows作用的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • SpringBoot整合redis+Aop防止重復(fù)提交的實(shí)現(xiàn)

    SpringBoot整合redis+Aop防止重復(fù)提交的實(shí)現(xiàn)

    Spring Boot通過AOP可以實(shí)現(xiàn)防止表單重復(fù)提交,本文主要介紹了SpringBoot整合redis+Aop防止重復(fù)提交的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • FasfDFS整合Java實(shí)現(xiàn)文件上傳下載功能實(shí)例詳解

    FasfDFS整合Java實(shí)現(xiàn)文件上傳下載功能實(shí)例詳解

    這篇文章主要介紹了FasfDFS整合Java實(shí)現(xiàn)文件上傳下載功能實(shí)例詳解,需要的朋友可以參考下
    2017-08-08
  • Java手寫Redis服務(wù)端的實(shí)現(xiàn)

    Java手寫Redis服務(wù)端的實(shí)現(xiàn)

    本文主要介紹了Java手寫Redis服務(wù)端的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • SpringBoot+SpringCloud用戶信息微服務(wù)傳遞實(shí)現(xiàn)解析

    SpringBoot+SpringCloud用戶信息微服務(wù)傳遞實(shí)現(xiàn)解析

    這篇文章主要介紹了SpringBoot+SpringCloud實(shí)現(xiàn)登錄用戶信息在微服務(wù)之間的傳遞,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • java二維數(shù)組實(shí)現(xiàn)推箱子小游戲

    java二維數(shù)組實(shí)現(xiàn)推箱子小游戲

    這篇文章主要為大家詳細(xì)介紹了java二維數(shù)組實(shí)現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11

最新評(píng)論