版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第SpringBoot詳解如何進(jìn)行整合Druid數(shù)據(jù)源目錄1.自定義方式1.添加依賴2.編寫配置3.測試2.starter方式(推薦)1.添加依賴2.編寫配置3.測試Druid是數(shù)據(jù)庫連接池,它能夠提供強(qiáng)大的監(jiān)控和擴(kuò)展功能。官方文檔
SpringBoot整合第三方技術(shù)的兩種方式:
自定義找starter場景
1.自定義方式
使用自定義方式整合Druid
1.添加依賴
在pom.xml添加相關(guān)依賴
!--數(shù)據(jù)庫相關(guān)--
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-data-jdbc/artifactId
/dependency
dependency
groupIdmysql/groupId
artifactIdmysql-connector-java/artifactId
version5.1.6/version
/dependency
dependency
groupIdcom.alibaba/groupId
artifactIddruid/artifactId
version1.2.6/version
/dependency
/dependencies
2.編寫配置
perties
server.port=8080
spring.datasource.url=jdbc:mysql://localhost:3306/db_springtestuseUnicode=truecharacterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
配置Druid的監(jiān)控頁功能:
Druid內(nèi)置提供了一個(gè)StatViewServlet用于展示Druid的統(tǒng)計(jì)信息。官方文檔-配置StatViewServlet
這個(gè)StatViewServlet的用途包括:
提供監(jiān)控信息展示的html頁面提供監(jiān)控信息的JSONAPI
Druid內(nèi)置提供一個(gè)StatFilter,用于統(tǒng)計(jì)監(jiān)控信息。官方文檔-配置_StatFilter
WebStatFilter用于采集web-jdbc關(guān)聯(lián)監(jiān)控的數(shù)據(jù),如SQL監(jiān)控、URI監(jiān)控。官方文檔-配置WebStatFilter
Druid提供了WallFilter,它是基于SQL語義分析來實(shí)現(xiàn)防御SQL注入攻擊的。官方文檔-配置wallfilter
DataSourceConfig
packagecom.limi.springboottest2.config;
importcom.alibaba.druid.pool.DruidDataSource;
importcom.alibaba.druid.support.http.StatViewServlet;
importcom.alibaba.druid.support.http.WebStatFilter;
importperties.ConfigurationProperties;
importorg.springframework.boot.web.servlet.FilterRegistrationBean;
importorg.springframework.boot.web.servlet.ServletRegistrationBean;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importjavax.sql.DataSource;
importjava.sql.SQLException;
importjava.util.Arrays;
@Configuration
publicclassDataSourceConfig{
@Bean
@ConfigurationProperties("spring.datasource")//復(fù)用配置文件的數(shù)據(jù)源配置,這樣就不用寫代碼一個(gè)一個(gè)set了
publicDataSourcedataSource()throwsSQLException{
DruidDataSourcedruidDataSource=newDruidDataSource();
//加入監(jiān)控和防火墻功能功能
druidDataSource.setFilters("stat,wall");
returndruidDataSource;
*配置druid的監(jiān)控頁功能
*@return
@Bean
publicServletRegistrationBeanstatViewServlet(){
StatViewServletstatViewServlet=newStatViewServlet();
ServletRegistrationBeanStatViewServletregistrationBean=
newServletRegistrationBean(statViewServlet,"/druid/*");
//監(jiān)控頁賬號密碼:
registrationBean.addInitParameter("loginUsername","admin");
registrationBean.addInitParameter("loginPassword","123456");
returnregistrationBean;
*WebStatFilter用于采集web-jdbc關(guān)聯(lián)監(jiān)控的數(shù)據(jù)。
@Bean
publicFilterRegistrationBeanwebStatFilter(){
WebStatFilterwebStatFilter=newWebStatFilter();
FilterRegistrationBeanWebStatFilterfilterRegistrationBean=newFilterRegistrationBean(webStatFilter);
filterRegistrationBean.setUrlPatterns(Arrays.asList("/*"));
filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");
returnfilterRegistrationBean;
}
3.測試
HelloController
packagecom.limi.springboottest2.controller;
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.jdbc.core.JdbcTemplate;
importorg.springframework.stereotype.Controller;
importorg.springframework.web.bind.annotation.GetMapping;
importorg.springframework.web.bind.annotation.ResponseBody;
@Controller
publicclassHelloController{
@Autowired
privateJdbcTemplatejdbcTemplate;
@ResponseBody
@GetMapping("/sql")
publicStringtest1(){
Stringsql="selectcount(*)fromt_user";
Longi=jdbcTemplate.queryForObject(sql,Long.class);
returni.toString();
}
多次點(diǎn)擊刷新進(jìn)行訪問
登錄druid后臺查看監(jiān)控信息
賬號admin,密碼123456
2.starter方式(推薦)
使用場景啟動(dòng)器整合druid,效果和自定義方式一樣,但更加方便
1.添加依賴
在pom.xml添加相關(guān)依賴
!--數(shù)據(jù)庫相關(guān)--
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-data-jdbc/artifactId
/dependency
dependency
groupIdmysql/groupId
artifactIdmysql-connector-java/artifactId
version5.1.6/version
/dependency
dependency
groupIdcom.alibaba/groupId
artifactIddruid-spring-boot-starter/artifactId
version1.1.17/version
/dependency
pom.xml完整內(nèi)容如下
xmlversion="1.0"encoding="UTF-8"
projectxmlns="/POM/4.0.0"xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/POM/4.0.0/xsd/maven-4.0.0.xsd"
modelVersion4.0.0/modelVersion
parent
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-parent/artifactId
version2.7.0/version
relativePath/!--lookupparentfromrepository--
/parent
groupIdcom.limi/groupId
artifactIdspringboot-test2/artifactId
version0.0.1-SNAPSHOT/version
namespringboot-test2/name
descriptionDemoprojectforSpringBoot/description
properties
java.version1.8/java.version
/properties
dependencies
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-web/artifactId
/dependency
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-devtools/artifactId
scoperuntime/scope
optionaltrue/optional
/dependency
dependency
groupIdjectlombok/groupId
artifactIdlombok/artifactId
optionaltrue/optional
/dependency
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-test/artifactId
scopetest/scope
/dependency
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-configuration-processor/artifactId
optionaltrue/optional
/dependency
!--數(shù)據(jù)庫相關(guān)--
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-data-jdbc/artifactId
/dependency
dependency
groupIdmysql/groupId
artifactIdmysql-connector-java/artifactId
version5.1.6/version
/dependency
dependency
groupIdcom.alibaba/groupId
artifactIddruid-spring-boot-starter/artifactId
version1.1.17/version
/dependency
/dependencies
build
plugins
plugin
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-maven-plugin/artifactId
configuration
excludes
exclude
groupIdjectlombok/groupId
artifactIdlombok/artifactId
/exclude
/excludes
/configuration
/plugin
!--下面插件作用是工程打包時(shí),不將spring-boot-configuration-processor打進(jìn)包內(nèi),讓其只在編碼的時(shí)候有用--
plugin
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-maven-plugin/artifactId
configuration
excludes
exclude
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-configuration-processor/artifactId
/exclude
/excludes
/configuration
/plugin
/plugins
/build
/project
2.編寫配置
perties
server.port=8080
spring.datasource.url=jdbc:mysql://localhost:3306/db_springtestuseUnicode=truecharacterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.druid.aop-patterns=com.limi.springboottest2.*
spring.datasource.druid.filters=stat,wall
spring.datasource.druid.stat-view-servlet.enabled=true
spring.datasource.druid.stat-view-servlet.login-username=admin
spring.datasource.druid.stat-view-servlet.login-password=123456
spring.datasource.druid.stat-view-servlet.reset-enable=false
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/*
spring.datasource.druid.filter.stat.slow-sql-millis=1000
spring.datasource.druid.filter.stat.log-sl
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- GB/T 32350.1-2025軌道交通絕緣配合第1部分:基本要求電工電子設(shè)備的電氣間隙和爬電距離
- 液狀化妝品制造工常識評優(yōu)考核試卷含答案
- 滴丸工安全規(guī)程知識考核試卷含答案
- 纖維碳化裝置操作工崗前技能競賽考核試卷含答案
- 鋁鎂粉球磨工崗前跨界整合考核試卷含答案
- 酒店員工培訓(xùn)與業(yè)務(wù)能力提升制度
- 酒店客房預(yù)訂與客戶關(guān)系管理規(guī)范制度
- 財(cái)務(wù)報(bào)告分析與改進(jìn)制度
- 城市酒店管理培訓(xùn)
- 丙烷購銷合同模板
- 2026 年初中英語《狀語從句》專項(xiàng)練習(xí)與答案 (100 題)
- 2026年遼寧省盤錦市高職單招語文真題及參考答案
- 農(nóng)投集團(tuán)安全生產(chǎn)制度
- 近五年貴州中考物理真題及答案2025
- 2025年黑龍江省大慶市中考數(shù)學(xué)試卷
- 2025年國補(bǔ)自查自糾報(bào)告
- 山東煙草2026年招聘(197人)考試備考試題及答案解析
- 二級醫(yī)院的DRGs培訓(xùn)課件
- 空芯光纖行業(yè)分析報(bào)告
- 2026年湖南中醫(yī)藥高等專科學(xué)校單招職業(yè)傾向性測試題庫及答案詳解一套
- 置業(yè)顧問崗位招聘考試試卷及答案
評論
0/150
提交評論