91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

spring cloud Hystrix斷路器的使用(熔斷器)

發布時間:2020-09-22 15:39:42 來源:腳本之家 閱讀:174 作者:TS笑天 欄目:編程語言

1.Hystrix客戶端

Netflix已經創建了一個名為Hystrix的庫,實現了斷路器的模式。在microservice架構通常有多個層的服務調用。

spring cloud Hystrix斷路器的使用(熔斷器)

低水平的服務的服務失敗會導致級聯故障一直給到用戶。當調用一個特定的服務達到一定閾值(默認5秒失敗20次),打開斷路器。在錯誤的情況下和一個開啟的斷路回滾應可以由開發人員提供。

spring cloud Hystrix斷路器的使用(熔斷器)

有一個斷路器阻止級聯失敗并且允許關閉服務一段時間進行愈合。回滾會被其他hystrix保護調用,靜態數據或健全的空值。
代碼如下:

@SpringBootApplication
@EnableCircuitBreaker
public class Application {

  public static void main(String[] args) {
    new SpringApplicationBuilder(Application.class).web(true).run(args);
  }

}
@Component
public class StoreIntegration {

  @HystrixCommand(fallbackMethod = "defaultStores")
  public Object getStores(Map<String, Object> parameters) {
    //do stuff that might fail
  }

  public Object defaultStores(Map<String, Object> parameters) {
    return /* something useful */;
  }
}

@HystrixCommand是由Netflix contrib 庫提供,叫做javanica。spring cloud自動包裝Spring bean與注釋的代理連接到Hystrix斷路器。斷路器計算何時打開和關閉斷路,并在失敗的情況下做什么。

配置@HystrixCommand可以使用commandProperties屬性的列表@HystrixProperty注釋。詳細請看https://github.com/Netflix/Hystrix/tree/master/hystrix-contrib/hystrix-javanica#configuration
https://github.com/Netflix/Hystrix/wiki/Configuration

1.1 傳播安全上下文或者使用spring范圍

如果你想要一些線程本地上下文傳播到@HystrixCommand默認聲明將不會工作,因為它執行線程池中的命令(在超時的情況下)。

可以切換Hystrix使用一些配置用相同的線程調用者,或直接在注釋,讓它使用不同的“隔離策略”(Isolation Strategy)。

例如:

@HystrixCommand(fallbackMethod = "stubMyService",
  commandProperties = {
   @HystrixProperty(name="execution.isolation.strategy", value="SEMAPHORE")
  }
)
...

詳細內容請參考https://github.com/Netflix/Hystrix/wiki/Configuration

1.2 健康監控

連接的斷路器的狀態也暴露在調用應用程序的/health端點。

{
  "hystrix": {
    "openCircuitBreakers": [
      "StoreIntegration::getStoresByLocationLink"
    ],
    "status": "CIRCUIT_OPEN"
  },
  "status": "UP"
}

1.3 Hystrix Metrics Stream(hystrix指標流)

spring-boot-starter-actuator中實現了Hystrix metrics stream。暴露/hystrix.stream作為一個管理端點。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
  </dependency>

2.Hystrix dashboard

Hystrix的主要好處之一是它收集關于每個HystrixCommand組指標。Hystrix儀表板顯示每個斷路器的健康高效的方式。

spring cloud Hystrix斷路器的使用(熔斷器) 

運行Hystrix儀表板需要在spring boot主類上標注@EnableHystrixDashboard。然后訪問/ hystrix查看儀表盤,在hystrix客戶端應用使用/hystrix.stream監控。

2.1 turbine

看一個實例Hystrix數據對于整個系統的健康不是很有用。turbine是一個應用程序,該應用程序匯集了所有相關的/hystrix.stream端點到 /turbine.stream用于Hystrix儀表板。運行turbine使用@EnableTurbine注釋你的主類,使用spring-cloud-starter-turbine這個jar。配置請參考https://github.com/Netflix/Turbine/wiki/Configuration-(1.x)

唯一的區別是turbine.instanceUrlSuffix不需要端口號前綴,因為這是自動處理,除非turbine.instanceInsertPort = false。

turbine.appConfig配置是一個eureka服務ID列表,turbine將使用這個配置查詢實例。turbine stream在hystrix dashboard中使用如下的url配置:

http://my.turbine.server:8080/turbine.stream?cluster=,如果集群的名稱是default,集群參數可以忽略)。這個集群參數必須和turbine.aggregator.clusterConfig匹配。從eureka返回的值都是大寫的,因此我們希望下面的例子可以工作,如果一個app使用eureka注冊,并且被叫做customers:

turbine:
 aggregator:
  clusterConfig: CUSTOMERS
 appConfig: customers

clusterName可以使用SPEL表達式定義,在turbine.clusterNameExpression。

默認值是appName,意思是eureka服務ID最終將作為集群的key,例如customers的InstanceInfo有一個CUSTOMERS的appName。另外一個例子是turbine.clusterNameExpression=aSGName,將從AWS ASG name獲取集群名稱。

另一個例子:

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

在這種情況下,集群名稱從4個服務從其元數據映射,期望包含“SYSTEM”和“USER”。

所有的app使用default,你需要一個文字表達式(使用單引號):

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

spring cloud提供一個spring-cloud-starter-turbine,所有依賴項你需要運行一個turbine服務器。使用@EnableTurbine創建一個spring boot應用。

2.2 turbine AMQP

在某些環境中(如在PaaS),典型的turbine模型的指標從所有分布式Hystrix命令不起作用。在這種情況下,你可能想要你Hystrix命令推動指標turbine,和spring cloud,就要使用AMQP消息傳遞。所有您需要做的是在客戶端添加一個依賴spring-cloud-netflix-hystrix-amqp并確保代rabbitmq可用。(有關詳細信息,請參閱彈簧引導文檔如何配置客戶端憑據,但它應該工作的當地代理或云計算)。

hystrix相關的其他文章:

hystrix緩存功能的使用:https://www.jb51.net/article/145855.htm

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

如皋市| 冀州市| 南川市| 东乡县| 灌阳县| 浦城县| 高邑县| 柘荣县| 桦川县| 横山县| 静安区| 阿勒泰市| 柘城县| 都安| 胶州市| 盐亭县| 旬邑县| 巴彦淖尔市| 治县。| 澄城县| 湟中县| 蓝田县| 邮箱| 贵南县| 鄯善县| 双江| 石泉县| 拜城县| 越西县| 潜江市| 乌拉特中旗| 高邮市| 江达县| 修水县| 饶阳县| 衡水市| 雷州市| 巴彦淖尔市| 剑川县| 南安市| 贞丰县|