成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Spring Cloud 參考文檔(Hystrix超時(shí)和Ribbon客戶端)

pf_miles / 1523人閱讀

摘要:要運(yùn)行儀表板,請(qǐng)使用注解主類,然后訪問并將儀表板指向客戶端應(yīng)用程序中的單個(gè)實(shí)例的端點(diǎn)。連接到使用的端點(diǎn)時(shí),必須信任服務(wù)器使用的證書,如果證書不受信任,則必須將證書導(dǎo)入,以便儀表板成功連接到流端點(diǎn)。

Hystrix超時(shí)和Ribbon客戶端

使用包裝Ribbon客戶端的Hystrix命令時(shí),要確保將Hystrix超時(shí)配置為長(zhǎng)于配置的Ribbon超時(shí),包括可能進(jìn)行的任何可能的重試,例如,如果你的Ribbon連接超時(shí)為一秒,并且Ribbon客戶端可能會(huì)重試該請(qǐng)求三次,那么你的Hystrix超時(shí)應(yīng)該略大于三秒。

如何包含Hystrix儀表板

要在項(xiàng)目中包含Hystrix儀表板,請(qǐng)使用組ID為org.springframework.cloud和工件ID為spring-cloud-starter-netflix-hystrix-dashboard的啟動(dòng)器。

要運(yùn)行Hystrix儀表板,請(qǐng)使用@EnableHystrixDashboard注解Spring Boot主類,然后訪問/hystrix并將儀表板指向Hystrix客戶端應(yīng)用程序中的單個(gè)實(shí)例的/hystrix.stream端點(diǎn)。

連接到使用HTTPS的/hystrix.stream端點(diǎn)時(shí),JVM必須信任服務(wù)器使用的證書,如果證書不受信任,則必須將證書導(dǎo)入JVM,以便Hystrix儀表板成功連接到流端點(diǎn)。
Turbine

查看單個(gè)實(shí)例的Hystrix數(shù)據(jù)在系統(tǒng)整體運(yùn)行狀況方面不是很有用,Turbine是一個(gè)應(yīng)用程序,它將所有相關(guān)的/hystrix.stream端點(diǎn)聚合到一個(gè)組合的/turbine.stream中,以便在Hystrix儀表板中使用,從Eureka定位單個(gè)實(shí)例。運(yùn)行Turbine需要使用@EnableTurbine注解來注解主類(例如,通過使用spring-cloud-starter-netflix-turbine來設(shè)置類路徑),Turbine 1 wiki中所有記錄的配置屬性均適用。唯一的區(qū)別是turbine.instanceUrlSuffix不需要前置端口,因?yàn)槌?b>turbine.instanceInsertPort=false,否則會(huì)自動(dòng)處理。

默認(rèn)情況下,Turbine在注冊(cè)實(shí)例上查找/hystrix.stream端點(diǎn),方法是查找它在Eureka中的hostNameport條目,然后將/hystrix.stream附加到它。如果實(shí)例的元數(shù)據(jù)包含management.port,則使用它來代替/hystrix.stream端點(diǎn)的port值。默認(rèn)情況下,名為management.port的元數(shù)據(jù)條目等于management.port配置屬性,可以通過以下配置覆蓋它:
eureka:
  instance:
    metadata-map:
      management.port: ${management.port:8081}

turbine.appConfig配置鍵是turbine用于查找實(shí)例的Eureka serviceId列表,然后,turbine流在Hystrix儀表板中使用,其URL類似于以下內(nèi)容:

http://my.turbine.server:8080/turbine.stream?cluster=CLUSTERNAME

如果名稱是default,則可以省略cluster參數(shù),cluster參數(shù)必須與turbine.aggregator.clusterConfig中的條目匹配,從Eureka返回的值是大寫的,因此,如果有一個(gè)名為customers的應(yīng)用程序在Eureka注冊(cè),則以下示例有效:

turbine:
  aggregator:
    clusterConfig: CUSTOMERS
  appConfig: customers

如果需要自定義Turbine應(yīng)使用的集群名稱(因?yàn)槟悴幌M?b>turbine.aggregator.clusterConfig配置中存儲(chǔ)集群名稱),請(qǐng)?zhí)峁?b>TurbineClustersProvider類型的Bean。

clusterName可以通過turbine.clusterNameExpression中的SPEL表達(dá)式進(jìn)行自定義,其中根用作InstanceInfo的實(shí)例,默認(rèn)值為appName,這意味著Eureka serviceId成為群集鍵(即,customersInstanceInfoappNameCUSTOMERS)。另一個(gè)示例是turbine.clusterNameExpression=aSGName,它從AWS ASG名稱獲取集群名稱,以下清單顯示了另一個(gè)示例:

turbine:
  aggregator:
    clusterConfig: SYSTEM,USER
  appConfig: customers,stores,ui,admin
  clusterNameExpression: metadata["cluster"]

在前面的示例中,來自四個(gè)服務(wù)的集群名稱是從其元數(shù)據(jù)映射中提取的,并且應(yīng)該具有包含SYSTEMUSER的值。

要為所有應(yīng)用程序使用“default”群集,你需要一個(gè)字符串文字表達(dá)式(如果它在YAML中,則使用單引號(hào)并使用雙引號(hào)進(jìn)行轉(zhuǎn)義):

turbine:
  appConfig: customers,stores
  clusterNameExpression: ""default""

Spring Cloud提供了一個(gè)spring-cloud-starter-netflix-turbine,它具有運(yùn)行Turbine服務(wù)器所需的所有依賴關(guān)系,要添加Turbine,請(qǐng)創(chuàng)建一個(gè)Spring Boot應(yīng)用程序并使用@EnableTurbine對(duì)其進(jìn)行注解。

默認(rèn)情況下,Spring Cloud允許Turbine使用主機(jī)和端口來允許每個(gè)主機(jī)、每個(gè)集群有多個(gè)進(jìn)程,如果你希望Turbine內(nèi)置的原生Netflix行為不允許每個(gè)主機(jī)、每個(gè)群集有多個(gè)進(jìn)程(實(shí)例ID的鍵是主機(jī)名),請(qǐng)?jiān)O(shè)置turbine.combineHostPort=false。
集群端點(diǎn)

在某些情況下,了解Turbine中配置了哪些集群可能對(duì)其他應(yīng)用程序有用,為了支持這一點(diǎn),你可以使用/clusters端點(diǎn),它將返回所有已配置集群的JSON數(shù)組。

GET /clusters

[
  {
    "name": "RACES",
    "link": "http://localhost:8383/turbine.stream?cluster=RACES"
  },
  {
    "name": "WEB",
    "link": "http://localhost:8383/turbine.stream?cluster=WEB"
  }
]

可以通過將turbine.endpoints.clusters.enabled設(shè)置為false來禁用此端點(diǎn)。

Turbine流

在某些環(huán)境中(例如在PaaS設(shè)置中),從所有分布式Hystrix命令中提取指標(biāo)的經(jīng)典Turbine模型不起作用,在這種情況下,你可能希望讓Hystrix命令將指標(biāo)推送到Turbine,Spring Cloud通過消息傳遞實(shí)現(xiàn)這一點(diǎn)。要在客戶端上實(shí)現(xiàn)這一點(diǎn),請(qǐng)?zhí)砑右蕾?b>spring-cloud-netflix-hystrix-stream和你選擇的spring-cloud-starter-stream-*。有關(guān)代理以及如何配置客戶端憑據(jù)的詳細(xì)信息,請(qǐng)參閱Spring Cloud Stream文檔,對(duì)于本地代理,這應(yīng)該是開箱即用的。

在服務(wù)器端,創(chuàng)建一個(gè)Spring Boot應(yīng)用程序并使用@EnableTurbineStream注解它,Turbine Stream服務(wù)器需要使用Spring Webflux,因此spring-boot-starter-webflux需要包含在你的項(xiàng)目中,默認(rèn)情況下,在將spring-cloud-starter-netflix-turbine-stream添加到你的應(yīng)用程序時(shí),會(huì)包含spring-boot-starter-webflux。

然后,你可以將Hystrix儀表板指向Turbine Stream Server而不是多帶帶的Hystrix流,如果Turbine Stream在myhost上的端口8989上運(yùn)行,則將http://myhost:8989放入Hystrix儀表板的流輸入字段中,Circuit的前綴是各自的serviceId,后跟一個(gè)點(diǎn)(·),然后是Circuit名稱。

Spring Cloud提供了spring-cloud-starter-netflix-turbine-stream,它具有運(yùn)行Turbine Stream服務(wù)器所需的所有依賴關(guān)系,然后,你可以添加你選擇的流綁定器 — 例如spring-cloud-starter-stream-rabbit。

Turbine Stream服務(wù)器還支持cluster參數(shù),與Turbine服務(wù)器不同,Turbine Stream使用eureka serviceId作為集群名稱,這些不可配置。

如果Turbine Stream服務(wù)器在my.turbine.server上的8989端口上運(yùn)行,并且你的環(huán)境中有兩個(gè)eureka serviceId為customersproducts,則你的Turbine Stream服務(wù)器上將提供以下URL,default和空集群名將提供Turbine Stream服務(wù)器接收的所有指標(biāo)。

http://my.turbine.sever:8989/turbine.stream?cluster=customers
http://my.turbine.sever:8989/turbine.stream?cluster=products
http://my.turbine.sever:8989/turbine.stream?cluster=default
http://my.turbine.sever:8989/turbine.stream

因此,你可以將eureka serviceId用作Turbine儀表板(或任何兼容的儀表板)的集群名稱,你無需為Turbine Stream服務(wù)器配置任何屬性,如turbine.appConfig、turbine.clusterNameExpressionturbine.aggregator.clusterConfig。

Turbine Stream服務(wù)器使用Spring Cloud Stream從配置的輸入通道收集所有指標(biāo),這意味著它不會(huì)從每個(gè)實(shí)例主動(dòng)收集Hystrix指標(biāo),它只能提供每個(gè)實(shí)例已經(jīng)收集到輸入通道中的指標(biāo)。
上一篇:斷路器:Hystrix客戶端 下一篇:客戶端負(fù)載均衡器:Ribbon

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/74275.html

相關(guān)文章

  • Spring Cloud 參考文檔戶端負(fù)載均衡器:Ribbon

    摘要:客戶端負(fù)載均衡器是一個(gè)客戶端負(fù)載均衡器,可以讓你對(duì)和客戶端的行為進(jìn)行大量控制,已經(jīng)使用了,因此,如果你使用,此部分也適用。 客戶端負(fù)載均衡器:Ribbon Ribbon是一個(gè)客戶端負(fù)載均衡器,可以讓你對(duì)HTTP和TCP客戶端的行為進(jìn)行大量控制,F(xiàn)eign已經(jīng)使用了Ribbon,因此,如果你使用@FeignClient,此部分也適用。 Ribbon中的一個(gè)核心概念是命名客戶端,每個(gè)負(fù)載均...

    Songlcy 評(píng)論0 收藏0
  • spring-cloud-feign源碼深度解析

    摘要:內(nèi)部使用了的動(dòng)態(tài)代理為目標(biāo)接口生成了一個(gè)動(dòng)態(tài)代理類,這里會(huì)生成一個(gè)動(dòng)態(tài)代理原理統(tǒng)一的方法攔截器,同時(shí)為接口的每個(gè)方法生成一個(gè)攔截器,并解析方法上的元數(shù)據(jù),生成一個(gè)請(qǐng)求模板。的核心源碼解析到此結(jié)束了,不知道是否對(duì)您有無幫助,可留言跟我交流。 Feign是一個(gè)聲明式的Web服務(wù)客戶端。這使得Web服務(wù)客戶端的寫入更加方便 要使用Feign創(chuàng)建一個(gè)界面并對(duì)其進(jìn)行注釋。它具有可插拔注釋支持,包...

    vibiu 評(píng)論0 收藏0
  • Spring Cloud 參考文檔(斷路器:Hystrix戶端

    摘要:以下示例顯示了具有斷路器的最小服務(wù)器由名為的庫(kù)提供,在連接到斷路器的代理中自動(dòng)包裝帶有該注解的,斷路器計(jì)算何時(shí)打開和關(guān)閉電路以及在發(fā)生故障時(shí)應(yīng)采取的措施。上一篇服務(wù)發(fā)現(xiàn)下一篇超時(shí)和客戶端 斷路器:Hystrix客戶端 Netflix創(chuàng)建了一個(gè)名為Hystrix的庫(kù),用于實(shí)現(xiàn)斷路器模式,在微服務(wù)架構(gòu)中,通常有多層服務(wù)調(diào)用,如以下示例所示: 較低級(jí)別的服務(wù)中的服務(wù)故障可能導(dǎo)致級(jí)聯(lián)故障一直到...

    novo 評(píng)論0 收藏0
  • SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)

    摘要:注意注解能注冊(cè)到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔?,該是一個(gè)復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。 SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力 - 一、大致介紹 1、本章節(jié)添加另外一個(gè)屬性 listOfServers 來給 zuul 賦上異樣的功能色彩,提供負(fù)載均衡的能力; 2、而其實(shí)說...

    Dogee 評(píng)論0 收藏0
  • SpringCloud(第 015 篇)電影Ribbon微服務(wù)集成Hystrix增加隔離策略控制指標(biāo)

    摘要:傳播安全上下文或使用,通過增加的屬性,來增加相關(guān)的配置來達(dá)到執(zhí)行隔離策略,控制線程數(shù)或者控制并發(fā)請(qǐng)求數(shù)來達(dá)到熔斷降級(jí)的作用。 SpringCloud(第 015 篇)電影Ribbon微服務(wù)集成Hystrix增加隔離策略控制線程數(shù)或請(qǐng)求數(shù)來達(dá)到熔斷降級(jí)的作用 - 一、大致介紹 1、本章節(jié)介紹關(guān)于Hystrix的2種隔離方式(Thread Pool 和 Semaphores); 2、Thr...

    RobinQu 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

pf_miles

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<