溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

springcloud中如何實現(xiàn)熔斷監(jiān)控Turbine

發(fā)布時間:2021-12-29 13:56:10 來源:億速云 閱讀:145 作者:小新 欄目:軟件技術(shù)

小編給大家分享一下springcloud中如何實現(xiàn)熔斷監(jiān)控Turbine,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在復(fù)雜的分布式系統(tǒng)中,相同服務(wù)的節(jié)點經(jīng)常需要部署上百甚至上千個,很多時候,運維人員希望能夠把相同服務(wù)的節(jié)點狀態(tài)以一個整體集群的形式展現(xiàn)出來,這樣可以更好的把握整個系統(tǒng)的狀態(tài)。 為此,Netflix提供了一個開源項目(Turbine)來提供把多個hystrix.stream的內(nèi)容聚合為一個數(shù)據(jù)源供Dashboard展示。

1、添加依賴

<dependencies>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-turbine</artifactId>
	</dependency>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-netflix-turbine</artifactId>
	</dependency>
	<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-actuator</artifactId>
	</dependency>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
	</dependency>
</dependencies>

2、配置文件

spring.application.name=hystrix-dashboard-turbine
server.port=8001
turbine.appConfig=node01,node02
turbine.aggregator.clusterConfig= default
turbine.clusterNameExpression= new String("default")
 
eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

turbine.appConfig :配置Eureka中的serviceId列表,表明監(jiān)控哪些服務(wù)

turbine.aggregator.clusterConfig :指定聚合哪些集群,多個使用”,”分割,默認(rèn)為default??墒褂胔ttp://.../turbine.stream?cluster={clusterConfig之一}訪問

turbine.clusterNameExpression : 1. clusterNameExpression指定集群名稱,默認(rèn)表達(dá)式appName;此時:turbine.aggregator.clusterConfig需要配置想要監(jiān)控的應(yīng)用名稱;2. 當(dāng)clusterNameExpression: default時,turbine.aggregator.clusterConfig可以不寫,因為默認(rèn)就是default;3. 當(dāng)clusterNameExpression: metadata[‘cluster’]時,假設(shè)想要監(jiān)控的應(yīng)用配置了eureka.instance.metadata-map.cluster: ABC,則需要配置,同時turbine.aggregator.clusterConfig: ABC

3、啟動類

啟動類添加@EnableTurbine,激活對Turbine的支持

@SpringBootApplication
@EnableHystrixDashboard
@EnableTurbine
public class DashboardApplication {
 
	public static void main(String[] args) {
		SpringApplication.run(DashboardApplication.class, args);
	}
 
}

到此Turbine(hystrix-dashboard-turbine)配置完成

4、測試

在示例項目spring-cloud-consumer-hystrix基礎(chǔ)上修改為兩個服務(wù)的調(diào)用者spring-cloud-consumer-node1和spring-cloud-consumer-node2

spring-cloud-consumer-node1項目改動如下: application.properties文件內(nèi)容

spring.application.name=node01
server.port=9001
feign.hystrix.enabled=true
 
eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

spring-cloud-consumer-node2項目改動如下: application.properties文件內(nèi)容

spring.application.name=node02
server.port=9002
feign.hystrix.enabled=true
 
eureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

HelloRemote類修改:

@FeignClient(name= "spring-cloud-producer2", fallback = HelloRemoteHystrix.class)
public interface HelloRemote {
 
    @RequestMapping(value = "/hello")
    public String hello2(@RequestParam(value = "name") String name);
 
}

對應(yīng)的HelloRemoteHystrix和ConsumerController類跟隨修改,具體查看代碼

修改完畢后,依次啟動spring-cloud-eureka、spring-cloud-consumer-node1、spring-cloud-consumer-node1、hystrix-dashboard-turbine(Turbine)

打開eureka后臺可以看到注冊了三個服務(wù):

springcloud中如何實現(xiàn)熔斷監(jiān)控Turbine

訪問 http://localhost:8001/turbine.stream

返回:

: ping
data: {"reportingHostsLast10Seconds":1,"name":"meta","type":"meta","timestamp":1494921985839}

并且會不斷刷新以獲取實時的監(jiān)控數(shù)據(jù),說明和單個的監(jiān)控類似,返回監(jiān)控項目的信息。進(jìn)行圖形化監(jiān)控查看,輸入:http://localhost:8001/hystrix,返回酷酷的小熊界面,輸入: http://localhost:8001/turbine.stream,然后點擊 Monitor Stream ,可以看到出現(xiàn)了倆個監(jiān)控列表

springcloud中如何實現(xiàn)熔斷監(jiān)控Turbine

以上是“springcloud中如何實現(xiàn)熔斷監(jiān)控Turbine”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI