SpringCloud學習筆記(3)——Hystrix

来源:http://www.cnblogs.com/cjsblog/archive/2017/12/05/7988979.html
-Advertisement-
Play Games

參考Spring Cloud官方文檔第13、14、15章 13. Circuit Breaker: Hystrix Clients Netflix提供了一個叫Hystrix的類庫,它實現了斷路器模式。在微服務架構中,通常一個微服務會調用多個其他的微服務。一個相對低層級的服務失敗可能造成上層應用的級聯 ...


參考Spring Cloud官方文檔第13、14、15章

13. Circuit Breaker: Hystrix Clients

Netflix提供了一個叫Hystrix的類庫,它實現了斷路器模式。在微服務架構中,通常一個微服務會調用多個其他的微服務。一個相對低層級的服務失敗可能造成上層應用的級聯失敗,服務訪問量越大失敗率越高。當斷路打開的時候,這個調用就被終止了。打開的斷路可以阻止級聯失敗。

13.1 How to Include Hystrix


15.1 How to Include Hystrix Dashboard

為了使用Hystrix儀錶盤,需要在Spring Boot main class上用@EnableHystrixDashboard註解標註。

 

上代碼

在原先的ribbon-demo基礎上修改

以上是在Ribbon中使用Hystrix,而Feign預設就支持Hystrix。下麵看一下在Feign中如何使用Hystrix。

17.4 Feign Hystrix Support

如果Hystrix在classpath中,並且feign.hystrix.enabled=true的話,那麼Feign將用斷路器包裝所有的方法。

註意:在Spring Cloud Dalston之前的版本中,如果classpath中有Hystrix,那麼Feign預設回為所有的方法加上斷路器。這種預設的行為在Spring Cloud Dalston版本中被改變了,取而代之的是可選的。

17.5 Feign Hystrix Fallbacks

Hystrix支持回調,當斷路器打開的時候回回調預設的代碼。為了回調指定的方法,可以在@FeignClient中設置fallback屬性,它的值是類的名字。例如:

 

 如果需要獲得回調觸發的原因,可以使用@FeignClient的fallbackFactory屬性。

上代碼

基於先前的feigen-demo工程改造

 

其它的不變

個人感覺還是用@EnableCircuitBreaker+@HystrixCommand的方式更方便一點兒

 至於斷路器儀錶盤還是跟前面一樣配置

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • python有一個很有意思的語法糖你可以直接寫1, =, !=, == 比如一個典型的 它實質是如下的邏輯關係 同樣1 ...
  • Mybatis的簡介: MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,並且改名為MyBatis 。2013年11月遷移到Github. MyBatis 是一款優秀的持久層框架,它 ...
  • 1) 編寫演算法函數int equal(tree t1, tree t2),判斷兩棵給定的樹是否等價; 2) 編寫演算法函數void preorder(bintree t)實現二叉樹t的非遞歸前序遍歷; 3)編寫演算法函數degree(LinkedGraph g)輸出以鄰接表為存儲結構的無向圖的各頂點的度 ...
  • 在spring boot使用的過程中, 發現我修改了靜態文件, 前臺刷新後, 沒有任何變化, 必須重新啟動, 才能看到, 這簡直不能讓人接受. 那有什麼方法來解決這個問題呢. Baidu之後, 得到了想要的答案, 在這裡記錄下來. 1. pom.xml 修改 在pom.xml文件中, 加入此配置, ...
  • 題目描述 丁丁最近沉迷於一個數字游戲之中。這個游戲看似簡單,但丁丁在研究了許多天之後卻發覺原來在簡單的規則下想要贏得這個游戲並不那麼容易。游戲是這樣的,在你面前有一圈整數(一共n個),你要按順序將其分為m個部分,各部分內的數字相加,相加所得的m個結果對10取模後再相乘,最終得到一個數k。游戲的要求是 ...
  • 1、到官網http://www.oracle.com/technetwork/java/javase/downloads/index.html下載JDK 2、安裝 打開dmg包 3、測試 在終端上輸入: java version 安裝完成。 ...
  • 前言 java8里最大亮點是lambda,讓我們用習慣C# linq的語法,也能眼前一亮。但是比起C#的語法糖還是差的很遠。 差集、並集、交集 ...
  • 定義: 將一個類的介面轉換成客戶希望的另外一個介面。適配器模式使得原本由於介面不相容而不能一起工作的那些類可以一起工作。 角色: 目標(Target)角色:這就是所期待得到的介面,也就是這類的介面是符合我們要求的。 源(Adapee)角色:我們要使用的介面,但是這個介面不符合我們的要求,也就是現在需 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...