Hystrix監(jiān)控的配置詳解

hystrix監(jiān)控.png

在微服務(wù)架構(gòu)中接奈,hystrix處理容錯(cuò)外,還有實(shí)時(shí)監(jiān)控功能通孽,在服務(wù)發(fā)生調(diào)用時(shí)序宦,會(huì)將每秒請求數(shù)、成功請求數(shù)等運(yùn)行指標(biāo)記錄下來背苦。

本文示例代碼:springcloud-demo
其中本文相關(guān)的項(xiàng)目有:

  • 服務(wù)發(fā)現(xiàn) Eureka Server: discovery
  • 鏈路追蹤 sleuth+zipkin:trace
  • 服務(wù)提供者:hello
  • 服務(wù)提供者: world
  • 服務(wù)消費(fèi)者: helloworld
  • 服務(wù)消費(fèi)者: helloworld-feign
  • 服務(wù)調(diào)用監(jiān)控: hystrix-dashboard
  • 監(jiān)控聚合: hystrix-turbine
  • 監(jiān)控聚合(消息中間件): hystrix-turbine-mq

通過接口的監(jiān)控

啟動(dòng)helloworld項(xiàng)目后互捌,訪問http://localhost:8020/message后,再次訪問http://localhost:8020/hystrix.stream可以看到界面不斷地輸出監(jiān)控日志行剂,監(jiān)控日志里包含了各種指標(biāo)(各種指標(biāo)信息請參考官方文檔)秕噪。

按照同樣的步驟操作helloworld-feign項(xiàng)目后,卻發(fā)現(xiàn)找不到該頁面厚宰,這是因?yàn)樾枰鲆恍┤缦屡渲茫?br> pom.xml引入hystrix依賴

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
        </dependency>

在啟動(dòng)類上加上@EnableCircuitBreaker注解腌巾,再次執(zhí)行上述操作,界面不斷輸出監(jiān)控日志铲觉。

helloworld-feign的hystrix監(jiān)控日志.png

使用hystrix-board對監(jiān)控進(jìn)行圖形化展示

上面的日志信息不夠直觀澈蝙,借助hystrix-dashboard可對監(jiān)控進(jìn)行圖形化展示。

  • 在service創(chuàng)建hystrix-dashboard項(xiàng)目
  • 引入hystrix-dashboard依賴
    <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
        </dependency>

  • 啟動(dòng)類配置@EnableHystrixDashboard注解(同時(shí)配置@EnableDiscoveryClient向注冊中心注冊撵幽,方便管理)
  • 配置文件設(shè)置端口
server:
  port: 8087

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${server.port}
spring:
  application:
    name: hystrix-dashboard


  • 測試結(jié)果
    啟動(dòng)hystrix-dashboard后灯荧,輸入http://localhost:8087/hystrix地址,出現(xiàn)文章第一張圖所示的界面盐杂。在第一個(gè)文本框輸入http://localhost:8020/hystrix.stream或者http://localhost:8030/hystrix.stream后點(diǎn)擊Monitor Stream則會(huì)顯示如下監(jiān)控結(jié)果:
20.png

以上的hystrix-dashboard每次只能輸入一個(gè)監(jiān)控地址逗载,在微服務(wù)架構(gòu)中往往有很多無法需要監(jiān)控,該怎么辦呢况褪?

可以使用Turbine聚合監(jiān)控?cái)?shù)據(jù)撕贞,讓hystrix-dashboard顯示這個(gè)聚合數(shù)據(jù)后的地址。

Turbine聚合監(jiān)控?cái)?shù)據(jù)

  • 創(chuàng)建一個(gè)hystrix-turbine項(xiàng)目测垛,引入如下maven依賴
<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-turbine</artifactId>
        </dependency>

  • 啟動(dòng)類上配置@EnableTurbine注解
  • 配置文件application.yml指明要從收集哪些微服務(wù)的監(jiān)控?cái)?shù)據(jù)
server:
  port: 8088

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${server.port}
    prefer-ip-address: true
spring:
  application:
    name: hystrix-turbine
turbine:
  app-config: helloworld,helloworldfeign
  cluster-name-expression: "'default'"

注意turbine的配置捏膨,這里收集helloworldhellowordfeign日志

  • 啟動(dòng)項(xiàng)目hystrix-turbine后,在hystrix-dashboard中輸入http://localhost:8089/turbine.stream,則展示如下聚合結(jié)果:
使用Turbine聚合hystrix監(jiān)控?cái)?shù)據(jù)

以上Turbine聚合微服務(wù)的監(jiān)控?cái)?shù)據(jù),然后在hystrix-dashboard展示多個(gè)微服務(wù)的實(shí)時(shí)監(jiān)控?cái)?shù)據(jù)号涯。 但是Turbine也有它的局限性目胡,比如服務(wù)之間無法通信,服務(wù)不在Eureka Server上注冊链快,則Turbine無法收集到微服務(wù)的日志誉己。那么這種情況下,需要借助消息中間件來解決域蜗。

通過消息中間件RabbitMQ收集監(jiān)控?cái)?shù)據(jù)

微服務(wù)在發(fā)生調(diào)用時(shí)巨双,將監(jiān)控?cái)?shù)據(jù)存儲(chǔ)到RabbitMQ,監(jiān)控從RabbitMQ獲取數(shù)據(jù)進(jìn)行實(shí)時(shí)展示霉祸,這樣有利于微服務(wù)和監(jiān)控端進(jìn)行解耦筑累,可以解決不在服務(wù)中心注冊的服務(wù)的監(jiān)控?cái)?shù)據(jù)也可以被收集到。

  • 安裝RabbitMQ
    使用如下docker命令安裝RabbitMQ丝蹭,并暴露相應(yīng)的端口(本人開發(fā)機(jī)為linux環(huán)境慢宗,docker的使用可以極大提高軟件安裝和項(xiàng)目部署的效率,推薦使用docker)
 docker run -d --name rabbitmq -p 5673:5672 -p 15673:15672 docker.io/rabbitmq:3-management

這樣向外暴露5673的連接端口和15673的web端口奔穿,默認(rèn)用戶名密碼是guest镜沽。

安裝后的RabbitMQ.png

  • 微服務(wù)端修改,以便向RabbitMQ傳輸監(jiān)控日志
    本文以helloworld為例改造微服務(wù)贱田,pom中引入依賴
 <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-netflix-hystrix-stream</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-stream-rabbit</artifactId>

配置文件中加上連接RabbitMQ的配置

spring:
  rabbitmq:
    host: localhost
    port: 5673
    username: guest
    password: guest

重啟helloworld,并在瀏覽器輸入http://localhost:8020/message形成監(jiān)控?cái)?shù)據(jù)缅茉。

  • 新建hystrix-turbine-mq項(xiàng)目
    項(xiàng)目中引入turbine和rabbitmq依賴
    <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-turbine-stream</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
        </dependency>

啟動(dòng)類上配置@EnableTurbineStream注解
配置文件:

server:
  port: 8089

eureka:
  client:
    serviceUrl:


      defaultZone: http://localhost:8761/eureka/
  instance:
    instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${server.port}
    prefer-ip-address: true
spring:
  application:
    name: hystrix-turbine-mq
  rabbitmq:
    host: localhost
    port: 5673
    username: guest
    password: guest

這樣指明了監(jiān)控的數(shù)據(jù)來源。

  • 測試結(jié)果
    啟動(dòng)hystrix-dashboard后湘换,輸入http://localhost:8089 即可展示如下的監(jiān)控結(jié)果:
    RabbitMQ收集監(jiān)控?cái)?shù)據(jù).png

本文參考了《Spring cloud 與Docker 微服務(wù)實(shí)戰(zhàn)》這本書宾舅。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末统阿,一起剝皮案震驚了整個(gè)濱河市彩倚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌扶平,老刑警劉巖帆离,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異结澄,居然都是意外死亡哥谷,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門麻献,熙熙樓的掌柜王于貴愁眉苦臉地迎上來们妥,“玉大人,你說我怎么就攤上這事勉吻〖嗌簦” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長惑惶。 經(jīng)常有香客問我煮盼,道長,這世上最難降的妖魔是什么带污? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任僵控,我火速辦了婚禮,結(jié)果婚禮上鱼冀,老公的妹妹穿的比我還像新娘报破。我一直安慰自己,他們只是感情好千绪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布泛烙。 她就那樣靜靜地躺著,像睡著了一般翘紊。 火紅的嫁衣襯著肌膚如雪蔽氨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天帆疟,我揣著相機(jī)與錄音鹉究,去河邊找鬼。 笑死踪宠,一個(gè)胖子當(dāng)著我的面吹牛自赔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柳琢,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼绍妨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了柬脸?” 一聲冷哼從身側(cè)響起他去,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎倒堕,沒想到半個(gè)月后灾测,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡垦巴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年媳搪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骤宣。...
    茶點(diǎn)故事閱讀 39,991評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秦爆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出憔披,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布拗胜,位于F島的核電站,受9級特大地震影響埂软,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜纫事,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一勘畔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧炫七,春花似錦、人聲如沸万哪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽奕巍。三九已至,卻和暖如春儒士,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背着撩。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留氓润,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓旺芽,卻偏偏與公主長得像辐啄,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子壶辜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評論 2 355

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