亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

SpringBoot集成阿里巴巴Druid監控的示例代碼

2024-07-14 08:40:22
字體:
來源:轉載
供稿:網友

druid是阿里巴巴開源的數據庫連接池,提供了優秀的對數據庫操作的監控功能,本文要講解一下springboot項目怎么集成druid。

本文在基于jpa的項目下開發,首先在pom文件中額外加入druid依賴,pom文件如下:

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.dalaoyang</groupId> <artifactId>springboot_druid</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springboot_druid</name> <description>springboot_druid</description> <parent>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-parent</artifactId>  <version>1.5.12.RELEASE</version>  <relativePath/> <!-- lookup parent from repository --> </parent> <properties>  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>  <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>  <java.version>1.8</java.version> </properties> <dependencies>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-data-jpa</artifactId>  </dependency>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-web</artifactId>  </dependency>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-devtools</artifactId>   <scope>runtime</scope>  </dependency>  <dependency>   <groupId>mysql</groupId>   <artifactId>mysql-connector-java</artifactId>   <scope>runtime</scope>  </dependency>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-test</artifactId>   <scope>test</scope>  </dependency>  <dependency>   <groupId>com.alibaba</groupId>   <artifactId>druid</artifactId>   <version>1.0.28</version>  </dependency> </dependencies> <build>  <plugins>   <plugin>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-maven-plugin</artifactId>   </plugin>  </plugins> </build></project>

application.properties上半段和整合jpa一點沒變,下面加入了一些druid的配置,如果對druid的配置有什么不理解的,可以去網上查一下。(這篇文章我覺得寫的很好,傳送門)

#端口號server.port=8888##validate 加載hibernate時,驗證創建數據庫表結構##create 每次加載hibernate,重新創建數據庫表結構,這就是導致數據庫表數據丟失的原因。##create-drop  加載hibernate時創建,退出是刪除表結構##update     加載hibernate自動更新數據庫結構##validate 啟動時驗證表的結構,不會創建表##none 啟動時不做任何操作spring.jpa.hibernate.ddl-auto=create##控制臺打印sqlspring.jpa.show-sql=true##數據庫配置##數據庫地址spring.datasource.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=false##數據庫用戶名spring.datasource.username=root##數據庫密碼spring.datasource.password=root##數據庫驅動spring.datasource.driver-class-name=com.mysql.jdbc.Driver#這里是不同的#使用druid的話 需要多配置一個屬性spring.datasource.typespring.datasource.type=com.alibaba.druid.pool.DruidDataSource # 連接池的配置信息# 初始化大小,最小,最大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記錄

然后在項目中加入DruidConfig,簡單講解一下,這個配置文件主要是加載application.properties的配置,代碼如下:

package com.dalaoyang.config;import java.sql.SQLException;import javax.sql.DataSource;import org.apache.log4j.Logger;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Primary;import com.alibaba.druid.pool.DruidDataSource;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.config * @email yangyang@dalaoyang.cn * @date 2018/4/12 */@Configurationpublic class DruidConfig { private Logger logger = Logger.getLogger(this.getClass()); @Value("${spring.datasource.url}") private String dbUrl; @Value("${spring.datasource.username}") private String username; @Value("${spring.datasource.password}") private String password; @Value("${spring.datasource.driver-class-name}") private String driverClassName; @Value("${spring.datasource.initialSize}") private int initialSize; @Value("${spring.datasource.minIdle}") private int minIdle; @Value("${spring.datasource.maxActive}") private int maxActive; @Value("${spring.datasource.maxWait}") private int maxWait; @Value("${spring.datasource.timeBetweenEvictionRunsMillis}") private int timeBetweenEvictionRunsMillis; @Value("${spring.datasource.minEvictableIdleTimeMillis}") private int minEvictableIdleTimeMillis; @Value("${spring.datasource.validationQuery}") private String validationQuery; @Value("${spring.datasource.testWhileIdle}") private boolean testWhileIdle; @Value("${spring.datasource.testOnBorrow}") private boolean testOnBorrow; @Value("${spring.datasource.testOnReturn}") private boolean testOnReturn; @Value("${spring.datasource.poolPreparedStatements}") private boolean poolPreparedStatements; @Value("${spring.datasource.maxPoolPreparedStatementPerConnectionSize}") private int maxPoolPreparedStatementPerConnectionSize; @Value("${spring.datasource.filters}") private String filters; @Value("{spring.datasource.connectionProperties}") private String connectionProperties; @Bean @Primary //主數據源 public DataSource dataSource(){  DruidDataSource datasource = new DruidDataSource();  datasource.setUrl(this.dbUrl);  datasource.setUsername(username);  datasource.setPassword(password);  datasource.setDriverClassName(driverClassName);  //configuration  datasource.setInitialSize(initialSize);  datasource.setMinIdle(minIdle);  datasource.setMaxActive(maxActive);  datasource.setMaxWait(maxWait);  datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);  datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);  datasource.setValidationQuery(validationQuery);  datasource.setTestWhileIdle(testWhileIdle);  datasource.setTestOnBorrow(testOnBorrow);  datasource.setTestOnReturn(testOnReturn);  datasource.setPoolPreparedStatements(poolPreparedStatements);  datasource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);  try {   datasource.setFilters(filters);  } catch (SQLException e) {   logger.error("druid configuration Exception", e);  }  datasource.setConnectionProperties(connectionProperties);  return datasource; }}

然后創建DruidFilter,代碼如下:

package com.dalaoyang.filter;import javax.servlet.annotation.WebFilter;import javax.servlet.annotation.WebInitParam;import com.alibaba.druid.support.http.WebStatFilter;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.filter * @email yangyang@dalaoyang.cn * @date 2018/4/12 */@WebFilter(filterName="druidWebStatFilter",urlPatterns="/*",  initParams={    @WebInitParam(name="exclusions",value="*.js,*.gif,*.jpg,*.bmp,*.png,*.css,*.ico,/druid/*")//忽略資源  })public class DruidFilter extends WebStatFilter {}

新建DruidServlet,在類上面加注解@WebServlet,其中配置了登錄druid監控頁面的賬號密碼,白名單黑名單之類的配置,代碼如下:

package com.dalaoyang.servlet;import javax.servlet.annotation.WebInitParam;import javax.servlet.annotation.WebServlet;import com.alibaba.druid.support.http.StatViewServlet;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.servlet * @email yangyang@dalaoyang.cn * @date 2018/4/12 */@WebServlet(urlPatterns="/druid/*",  initParams={    @WebInitParam(name="allow",value=""),// IP白名單(沒有配置或者為空,則允許所有訪問)    @WebInitParam(name="deny",value=""),// IP黑名單 (deny優先于allow)    @WebInitParam(name="loginUsername",value="admin"),// 登錄druid管理頁面用戶名    @WebInitParam(name="loginPassword",value="admin")// 登錄druid管理頁面密碼  })public class DruidServlet extends StatViewServlet {}

然后在啟動類加入注解@ServletComponentScan,讓項目掃描到servlet,代碼如下:

package com.dalaoyang;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.boot.web.servlet.ServletComponentScan;@SpringBootApplication// 啟動類必須加入@ServletComponentScan注解,否則無法掃描到servlet@ServletComponentScanpublic class SpringbootDruidApplication { public static void main(String[] args) {  SpringApplication.run(SpringbootDruidApplication.class, args); }}

剩余的就是和整合jpa一樣的entity(實體類),repository(數據操作層),controller(測試使用的controller),直接展示代碼。

City

package com.dalaoyang.entity;import javax.persistence.*;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.Entity * @email 397600342@qq.com * @date 2018/4/7 */@Entity@Table(name="city")public class City { @Id @GeneratedValue(strategy=GenerationType.AUTO) private int cityId; private String cityName; private String cityIntroduce; public City(int cityId, String cityName, String cityIntroduce) {  this.cityId = cityId;  this.cityName = cityName;  this.cityIntroduce = cityIntroduce; } public City(String cityName, String cityIntroduce) {  this.cityName = cityName;  this.cityIntroduce = cityIntroduce; } public City() { } public int getCityId() {  return cityId; } public void setCityId(int cityId) {  this.cityId = cityId; } public String getCityName() {  return cityName; } public void setCityName(String cityName) {  this.cityName = cityName; } public String getCityIntroduce() {  return cityIntroduce; } public void setCityIntroduce(String cityIntroduce) {  this.cityIntroduce = cityIntroduce; }}

CityRepository

package com.dalaoyang.repository;import com.dalaoyang.entity.City;import org.springframework.data.jpa.repository.JpaRepository;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.Repository * @email 397600342@qq.com * @date 2018/4/7 */public interface CityRepository extends JpaRepository<City,Integer> {}

CityController

package com.dalaoyang.controller;import com.dalaoyang.entity.City;import com.dalaoyang.repository.CityRepository;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;/** * @author dalaoyang * @Description * @project springboot_learn * @package com.dalaoyang.controller * @email 397600342@qq.com * @date 2018/4/7 */@RestControllerpublic class CityController { @Autowired private CityRepository cityRepository; //http://localhost:8888/saveCity?cityName=北京&cityIntroduce=中國首都 @GetMapping(value = "saveCity") public String saveCity(String cityName,String cityIntroduce){  City city = new City(cityName,cityIntroduce);  cityRepository.save(city);  return "success"; } //http://localhost:8888/deleteCity?cityId=2 @GetMapping(value = "deleteCity") public String deleteCity(int cityId){  cityRepository.delete(cityId);  return "success"; } //http://localhost:8888/updateCity?cityId=3&cityName=沈陽&cityIntroduce=遼寧省省會 @GetMapping(value = "updateCity") public String updateCity(int cityId,String cityName,String cityIntroduce){  City city = new City(cityId,cityName,cityIntroduce);  cityRepository.save(city);  return "success"; } //http://localhost:8888/getCityById?cityId=3 @GetMapping(value = "getCityById") public City getCityById(int cityId){  City city = cityRepository.findOne(cityId);  return city; }}

然后啟動項目,可以看到控制臺已經創建了city表。

SpringBoot,集成,Druid,監控,Druid監控

然后訪問http://localhost:8888/druid,可以看到如下圖:

SpringBoot,集成,Druid,監控,Druid監控

輸入賬號密碼admin,admin,如下圖

SpringBoot,集成,Druid,監控,Druid監控

然后這時我們可以訪問http://localhost:8888/saveCity?cityName=北京&cityIntroduce=中國首都

然后點擊導航上面的SQL監控,如下圖,

SpringBoot,集成,Druid,監控,Druid監控

從上圖可以看到啟動項目創建表的sql已經剛剛執行的sql。到這里整合已經完成了。

源碼下載 :https://gitee.com/dalaoyang/springboot_learn

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲色图综合网| 成人亚洲欧美一区二区三区| 亚洲人成免费电影| 亚洲自拍高清视频网站| 欧美日韩亚洲天堂| 麻豆一区二区在线观看| 国产精品男人爽免费视频1| 欧美性xxxxhd| 欧美性69xxxx肥| 亚洲黄在线观看| 国产不卡精品视男人的天堂| 欧美激情一区二区三区久久久| 国产精品情侣自拍| 97av在线视频| 久久影视免费观看| 久久亚洲国产成人| 国内外成人免费激情在线视频| 久久久久久久久久久网站| 中文字幕精品一区久久久久| 日韩精品在线视频观看| 91av在线精品| 欧美精品久久一区二区| 久久全国免费视频| 日韩国产激情在线| 国产专区欧美专区| 国产精品成人v| 国产精品国产三级国产aⅴ9色| 国内精品美女av在线播放| 欧美福利在线观看| 97热精品视频官网| 欧美性猛交xxxx乱大交3| 久久视频在线看| 92福利视频午夜1000合集在线观看| 欧美日韩精品在线播放| 亚洲精品美女免费| 日本一区二三区好的精华液| 久久精品国产电影| 91精品久久久久久久久中文字幕| 91色精品视频在线| 5566日本婷婷色中文字幕97| 黑人巨大精品欧美一区二区一视频| 成人伊人精品色xxxx视频| 91成品人片a无限观看| 久久在线免费观看视频| 在线观看国产欧美| 欧美视频免费在线| 91国产精品电影| 伊人成人开心激情综合网| 国产精品女人久久久久久| 亚洲男人第一av网站| 国产成人a亚洲精品| 成人激情在线播放| 久久国产一区二区三区| 欧美日韩精品二区| 欧美日韩激情视频8区| 国产日本欧美在线观看| 亚洲第一精品自拍| 91久久精品日日躁夜夜躁国产| 欧日韩不卡在线视频| 国产精品激情av在线播放| 久久夜色精品国产欧美乱| 精品国产户外野外| 国产欧美 在线欧美| 最近2019中文字幕一页二页| 国产精品亚洲视频在线观看| 中文字幕亚洲国产| 日韩成人在线电影网| 国产精品最新在线观看| 国产中文字幕亚洲| 色av中文字幕一区| 日韩av在线不卡| 日韩免费av一区二区| 成人在线播放av| 狠狠躁夜夜躁人人躁婷婷91| 欧美小视频在线| 最新中文字幕亚洲| 亚洲人成电影在线播放| 欧美国产乱视频| 欧美激情欧美狂野欧美精品| 日本久久久a级免费| 欧美亚洲一区在线| 日本欧美中文字幕| 日韩精品中文字幕视频在线| 91啪国产在线| 91精品视频在线播放| xvideos亚洲人网站| 亚洲欧美国产精品久久久久久久| www.色综合| 亚洲男人天堂2019| 都市激情亚洲色图| 亚洲女在线观看| 2019亚洲男人天堂| 国产日韩专区在线| 亚洲成人aaa| 成人疯狂猛交xxx| 久久久久久一区二区三区| 粉嫩老牛aⅴ一区二区三区| 欧美成人免费一级人片100| 538国产精品视频一区二区| 国产一区二区av| 欧美视频不卡中文| 91免费看片在线| 欧美亚洲国产日韩2020| 国产精品私拍pans大尺度在线| 久久视频这里只有精品| 热草久综合在线| 欧美电影免费观看网站| 国产精品综合不卡av| 国产精品自产拍在线观| www.99久久热国产日韩欧美.com| 国产精品自拍小视频| 亚洲午夜av久久乱码| 91在线精品视频| 亚洲片在线资源| www.国产精品一二区| 亚洲视屏在线播放| 成人在线免费观看视视频| 欧美日韩国产丝袜美女| 亚洲欧美第一页| 国内揄拍国内精品| 日韩中文字幕第一页| 欧美视频在线免费看| 欧美日韩国产精品一区二区不卡中文| 欧美性xxxxhd| 成人自拍性视频| 91国内在线视频| 国产精品一区二区三区成人| 中文字幕亚洲无线码在线一区| 亚洲精品久久久久国产| 亚洲精品成人久久电影| 久久不射热爱视频精品| 国产精品v日韩精品| 欧美日韩一区二区在线播放| 欧美日韩亚洲视频一区| 日本成人黄色片| 亚洲电影免费观看| 久久成人这里只有精品| 国产精品丝袜一区二区三区| 欧美高清videos高潮hd| 亚洲欧美在线第一页| 日韩精品亚洲视频| 欧美日韩另类字幕中文| 久久影视电视剧免费网站| 亚洲美女精品成人在线视频| 91免费国产网站| 欧美电影在线观看完整版| 欧美激情一区二区三区高清视频| 欧美日韩激情小视频| 国产91在线播放精品91| 欧美视频在线观看 亚洲欧| 欧美激情va永久在线播放| 永久免费毛片在线播放不卡| 97在线观看免费| 91tv亚洲精品香蕉国产一区7ujn| 日韩精品在线免费观看| 欧美国产精品日韩| 美女性感视频久久久| 精品小视频在线| 国内外成人免费激情在线视频| 欧美久久精品午夜青青大伊人| 久久影视免费观看| 亚洲精品永久免费精品| 久久久久久久电影一区| 亚洲丝袜在线视频|