springboot中加入druid對sql進行監控

来源:https://www.cnblogs.com/ccxp/archive/2018/08/18/9497328.html
-Advertisement-
Play Games

springboot作為現在十分流行的框架,簡化Spring應用的初始搭建以及開發過程,現在我們就使用springboot來進行簡單的web項目搭建並對項目sql進行監控。 項目的搭建就省略了,springboot項目搭建好以後,進行一下操作, 本例子的項目使用 maven 管理的jar 1.加入依 ...


springboot作為現在十分流行的框架,簡化Spring應用的初始搭建以及開發過程,現在我們就使用springboot來進行簡單的web項目搭建並對項目sql進行監控。

項目的搭建就省略了,springboot項目搭建好以後,進行一下操作, 本例子的項目使用 maven 管理的jar

1.加入依賴, 在pom.xml文件 增加配置

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

2、
配置數據源 ,  在appcation.yml文件加入druid的數據源配置 
# 資料庫訪問配置
# 主數據源,預設的
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/demo
spring.datasource.username=root
spring.datasource.password=admin

# 下麵為連接池的補充設置,應用到上面所有數據源中
# 初始化大小,最小,最大
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
# 配置獲取連接等待超時的時間
spring.datasource.maxWait=60000
# 配置間隔多久才進行一次檢測,檢測需要關閉的空閑連接,單位是毫秒
spring.datasource.timeBetweenEvictionRunsMillis=60000
# 配置一個連接在池中最小生存的時間,單位是毫秒
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
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
spring.jpa.database=mysql
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
spring.jpa.hibernate.naming.strategy=org.hibernate.cfg.ImprovedNamingStrategy

3.使用註解的方式,增加druid的過濾器 ,新增一個類 DruidStatFilter.java
import com.alibaba.druid.support.http.WebStatFilter;
import javax.servlet.annotation.WebFilter;
import javax.servlet.annotation.WebInitParam;


@WebFilter(filterName = "druidWebStatFilter", urlPatterns = "/*",
initParams = {
@WebInitParam(name = "exclusions", value = "*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*")// 忽略資源
})
public class DruidStatFilter extends WebStatFilter {

}

4.使用註解的方式 增加 DruidStatViewServlet.java 服務類
import com.alibaba.druid.support.http.StatViewServlet;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;

@SuppressWarnings("serial")
@WebServlet(urlPatterns = "/druid/*", initParams = {
@WebInitParam(name = "allow", value = ""), // IP白名單
@WebInitParam(name = "deny", value = ""),
// IP黑名單
@WebInitParam(name = "loginUsername", value = "admin"), // 用戶名
@WebInitParam(name = "loginPassword", value = "admin*druid"), // 密碼
@WebInitParam(name = "resetEnable", value = "true")})
public class DruidStatViewServlet extends StatViewServlet {

}

5.這裡有個很重要的事情一定不要忘了在啟動類中加上servlet的掃描註解
@ServletComponentScan(value = "自己的包")
6.按理說現在druid就搭建好了可以通過http://localhost:8080/druid/index.html進行正常訪問了,但是在操作中我發現sql監控並沒有起到作用,也就是並沒有sql監控的記錄,在多次查閱資料後,
終於找到解決辦法,雖然我們在配置文件application.properties中已經配置了druid數據源,但是在這裡我們需要再次將這個DataSource配置到java配置中,這裡我們將這個配置直接寫入到啟動類中。
@Bean
@ConfigurationProperties(prefix="spring.datasource")
public DataSource druidDataSource() {
   return new DruidDataSource();
}
 




您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • @@@@首先開啟系統,出現下圖界面以後,按e鍵。 @@@使用下放下箭頭找到圖中的位置,在下圖中 修改 ro 為 rw , 添加init=sysroot/bin/sh @@@按Ctrl + x 進入單用戶模式,並 輸入 chroot /sysroot,進入系統命令,然後輸入 passwd root進行 ...
  • 書籍方面的推薦就不做介紹,免得別人說我有廣告嫌疑。大家可以直接上百度,書籍和視頻遍地都是,Linux這些方面的知識都是自己在學習視頻和看書的總結,內容上可能會不完美。如果有更多的見解,歡迎直接評論。 書籍方面的推薦就不做介紹,免得別人說我有廣告嫌疑。大家可以直接上百度,書籍和視頻遍地都是,Linux ...
  • 最近在學Win32的編程,看的是《Windows程式設計第5版》一書,這本書是臺灣人翻譯的,有些譯法和大陸不一樣,書中還有一些錯誤的地方,很多時候需要中英文對照閱讀,下載請點擊 https://download.csdn.net/download/u013238941/10611720 好了,下麵開 ...
  • 基本語法:select 查詢列表 from 表名 查詢列表可以是表中欄位、常量值、表達式、函數;查詢的結果是一個虛擬的表格。 註意: ①sql語言大小寫不敏感 ②關鍵字不能分行或略寫 ③一般書寫方式為換行縮進 一、基礎查詢 1.經典查詢(查詢表中的欄位) ①查詢單個欄位 select 欄位1 fro ...
  • DDL(Data Definition languages)數據定義語言,這些語句主要定義了不同的數據段,數據表、列、索引等操作,主要關鍵字有create、drop、alter。 一、 資料庫的操作 1.資料庫的創建 CREATE DATABASE IF NOT EXISTS chens; 2.數據 ...
  • 定義:數據操作語言主要實現對資料庫表中的數據進行操作,主要包括插入(insert)、更新(update)、刪除(delete)、查詢(select),本節主要介紹增刪改。 數據準備: 一、數據的插入(insert) 基本語法: insert into 表名(列名,...) values(值1,... ...
  • 1、Oracle win64_12g 安裝 1.下載安裝包:這裡需要自己註冊一下,然後就可以登錄下載軟體了。 下載地址: "http://www.oracle.com/technetwork/database/enterprise edition/downloads/index.html" 記得下載 ...
  • 1)安裝mysql ubuntu中安裝一臺mysql了,docker安裝另外一臺mysql 獲取mysql的鏡像,主從同步儘量保證多台mysql的版本相同,我的ubuntu中存在的mysql是5.7.22版本,所以獲取5.7.22版本的鏡像為例: 運行mysql docker鏡像,需要在宿主機中建立 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...