springboot+dubbo+druid(監(jiān)控)

一.部署dubbo-admin后臺(便于觀察)
1.安裝/啟動zookeeper(略)舀武,注意規(guī)避8080端口(一些版本的zookeeper啟動后會占用8080,網(wǎng)上有解決辦法)
2.下載dubbo-admin(地址https://github.com/apache/incubator-dubbo-ops)
3.進入dubbo-admin下運行maven指令打包:mvn package -Dmaven.skip.test=true

dubbo-admin-war.PNG

4.將dubbo-admin-2.0.0.war丟入tomcat(D:\dev\apache-tomcat-8.0.46\webapps)骏啰,啟動后节吮,在..\apache-tomcat-8.0.46\webapps中會生產(chǎn)dubbo-admin-2.0.0的文件夾
image.png

5.訪問http://127.0.0.1:8082/dubbo-admin-2.0.0/, 賬號/密碼: root/root
image.png

二. 項目創(chuàng)建和環(huán)境搭建
1.http://www.reibang.com/p/6361a670ebf7
2.http://www.reibang.com/p/0837b48d1691

三.整合druid數(shù)據(jù)源(->mysql)
參考:https://www.cnblogs.com/hlhdidi/p/6350306.html
https://blog.csdn.net/qq_34531925/article/details/78904897 (Druid數(shù)據(jù)庫配置詳細介紹)
https://www.cnblogs.com/softidea/p/6071630.html
1.在boot-dubbo-provider模塊下的pom.xml中添加依賴

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.10</version>
</dependency>

2.Druid數(shù)據(jù)源配置

server:
  port: 8071
  context-path: /
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mytest?useUnicode=true&characterEncoding=UTF-8
    username: root
    password:
    driver-class-name: com.mysql.jdbc.Driver
    platform: mysql
    initialSize: 5
    minIdle: 5
    maxActive: 20
    timeBetweenEvictionRunsMillis: 60000
    minEvictableIdleTimeMillis: 300000
    validationQuery: SELECT 1 FROM DUAL
    testWhileIdle: true
    testOnBorrow: false
    testOnReturn: false
    poolPreparedStatements: true
    maxPoolPreparedStatementPerConnectionSize: 20
    filters: stat,wall,log4j
    connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000
    useGlobalDataSourceStat: true
mybatis:
  mapper-locations: ['mapper/*.xml']

3.建立DruidConfiguration配置類,配置過濾信息(配置完,數(shù)據(jù)庫連接池便實現(xiàn))

@Configuration
@ConditionalOnClass(value = {MapperScannerConfigurer.class,     
DataSourceTransactionManager.class})
@EnableTransactionManagement(proxyTargetClass = true)
public class MysqlDBConfig {
  @Autowired
  @Qualifier("mysqlDB")
  private DataSource ds;
  @Bean(name = "mysqlDB")
  @ConfigurationProperties(prefix = "spring.datasource")
  public DataSource dataSource() {
      return       
 DataSourceBuilder.create().type(com.alibaba.druid.pool.DruidDataSource.class).build();
   }
 }

4.配置數(shù)據(jù)庫監(jiān)控
4.1 依賴

     <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>4.0.1</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <version>2.0.1.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <version>9.0.6</version>
    </dependency>

4.2 在MysqlDBConfig中新增方法

import javax.sql.DataSource;

import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
import org.springframework.boot.context.properties.ConfigurationProperties;
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;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

/**
 * 
* @ClassName: OracleDBConfig  
* @Description: oracle數(shù)據(jù)源配置  
* @author liyang  
* @date 2018年5月4日  
*
 */
@Configuration
@ConditionalOnClass(value = {MapperScannerConfigurer.class, DataSourceTransactionManager.class})
@EnableTransactionManagement(proxyTargetClass = true)
public class MysqlDBConfig {

    @Autowired
    @Qualifier("mysqlDB")
    private DataSource ds;

    @Bean(name = "mysqlDB")
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return DataSourceBuilder.create().type(com.alibaba.druid.pool.DruidDataSource.class).build();
    }

    /**
     * druid 監(jiān)控
     * @return
     */
    @Bean
    public ServletRegistrationBean statViewServle(){
        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(),"/druid/*");
        //白名單:
//        servletRegistrationBean.addInitParameter("allow","192.168.1.218,127.0.0.1");
        //IP黑名單 (存在共同時判耕,deny優(yōu)先于allow) : 如果滿足deny的即提示:Sorry, you are not permitted to view this page.
//        servletRegistrationBean.addInitParameter("deny","192.168.1.100");
        //登錄查看信息的賬號密碼.
        servletRegistrationBean.addInitParameter("loginUsername","druid");
        servletRegistrationBean.addInitParameter("loginPassword","12345678");
        //是否能夠重置數(shù)據(jù).
        servletRegistrationBean.addInitParameter("resetEnable","false");
        return servletRegistrationBean;
    }

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

}

4.3 啟動后訪問:

碼云地址: https://gitee.com/googelchrome/boot-dubbo

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末透绩,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子祈秕,更是在濱河造成了極大的恐慌渺贤,老刑警劉巖雏胃,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件请毛,死亡現(xiàn)場離奇詭異,居然都是意外死亡瞭亮,警方通過查閱死者的電腦和手機方仿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來统翩,“玉大人仙蚜,你說我怎么就攤上這事〕Ш梗” “怎么了委粉?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長娶桦。 經(jīng)常有香客問我贾节,道長,這世上最難降的妖魔是什么衷畦? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任栗涂,我火速辦了婚禮,結(jié)果婚禮上祈争,老公的妹妹穿的比我還像新娘斤程。我一直安慰自己,他們只是感情好菩混,可當我...
    茶點故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布忿墅。 她就那樣靜靜地躺著,像睡著了一般沮峡。 火紅的嫁衣襯著肌膚如雪疚脐。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天帖烘,我揣著相機與錄音亮曹,去河邊找鬼橄杨。 笑死,一個胖子當著我的面吹牛照卦,可吹牛的內(nèi)容都是我干的式矫。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼役耕,長吁一口氣:“原來是場噩夢啊……” “哼采转!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起瞬痘,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤故慈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后框全,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體察绷,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年津辩,在試婚紗的時候發(fā)現(xiàn)自己被綠了拆撼。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡喘沿,死狀恐怖闸度,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蚜印,我是刑警寧澤莺禁,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站窄赋,受9級特大地震影響哟冬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜寝凌,卻給世界環(huán)境...
    茶點故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一柒傻、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧较木,春花似錦红符、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至峰锁,卻和暖如春萎馅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背虹蒋。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工糜芳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留飒货,地道東北人。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓峭竣,卻偏偏與公主長得像塘辅,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子皆撩,可洞房花燭夜當晚...
    茶點故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容