(七)SpringBoot+SpringCloud —— 集成斷路器

2019獨角獸企業重金招聘Python工程師標準>>> hot3.png

斷路器簡介

在一個項目中,系統可能被拆分成多個服務,例如用戶、訂單和庫存等。

這里存在這服務調用服務的情況,例如,客戶端調用訂單服務,訂單服務又調用庫存服務。

此時若庫存服務響應緩慢,會直接導致訂單服務的線程被掛起,以等待庫存申請服務的響應,在漫長的等待之后用戶會因為請求庫存失敗而得到創建訂單失敗的結果。

如果在高并發下,因這些掛起的線程在等待庫存服務的響應而未能獲得釋放,會似的后續到來的請求被阻塞,最終導致訂單服務也不可用。

在分布式架構中,斷路器模式的作用也是類似的,當某個服務單元發生故障之后,通過斷路器的故障監控,向調用方返回一個錯誤響應,而不是漫長的等待。

快速入門

首先,添加斷路器hystrix的依賴。

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

接著在工程的主類,添加注解@EnableCircuitBreaker:

package cn.net.bysoft.owl.bookstore.web.console;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;@SpringBootApplication
@EnableDiscoveryClient
@EnableCircuitBreaker
public class OwlBookstoreWebConsoleApplication {@Bean@LoadBalancedRestTemplate restTemplate() {return new RestTemplate();}public static void main(String[] args) {SpringApplication.run(OwlBookstoreWebConsoleApplication.class, args);}
}

接著,就可以使用斷路器了,可以添加@HystrixCommand注解,對調用服務的方法進行修飾:

	@HystrixCommand(fallbackMethod = "findByIdFallback")public User findById(Long id) {UriComponents uriComponents = UriComponentsBuilder.fromUriString("http://SERVICE-USER/users/{id}").build().expand(id).encode();URI uri = uriComponents.toUri();return restTemplate.getForObject(uri, User.class);}public User findByIdFallback(Long id) {return null;}

fallbackMethod是服務發生異常時,回調的降級處理函數,該函數的參數和返回值要與調用函數一致。

斷路器的默認超時時間為2000毫秒。當被斷路器修飾的函數執行超過這個值,將觸發斷路器的服務降級,該參數是可以設置的。

斷路器配置

全局配置屬性:hystrix.[attr].default.

實例配置屬性:hystrix.[attr].[key].

execution配置

  1. Command Properties
    1. Execution
      1. execution.isolation.strategy (執行的隔離策略)
      2. execution.isolation.thread.timeoutInMilliseconds(執行的超時時間)
      3. execution.timeout.enabled(是否啟用超時時間)
      4. execution.isolation.thread.interruptOnTimeout(超時發生后是否要中斷該服務)
      5. execution.isolation.thread.interruptOnCancel(執行被取消后是否要中斷該服務)
      6. execution.isolation.semaphore.maxConcurrentRequests(當最大并發達到該值,后續的請求會被拒絕)
    2. Fallback
      1. fallback.isolation.semaphore.maxConcurrentRequests(fallback方法執行的最大并發請求數,當達到最大,后續的請求將會被拒絕并拋出異常)
      2. fallback.enabled(服務降級策略是否啟用)
    3. Circuit Breaker
      1. circuitBreaker.enabled (斷路器開關)
      2. circuitBreaker.requestVolumeThreshold (斷路器請求閾值)
      3. circuitBreaker.sleepWindowInMilliseconds(斷路器休眠時間)
      4. circuitBreaker.errorThresholdPercentage(斷路器錯誤請求百分比)
      5. circuitBreaker.forceOpen(斷路器強制開啟)
      6. circuitBreaker.forceClosed(斷路器強制關閉)
    4. Metrics
      1. metrics.rollingStats.timeInMilliseconds(滾動時間窗長度,毫秒級)
      2. metrics.rollingStats.numBuckets(滾動時間窗統計指標信息時劃分“桶”的數量)
      3. metrics.rollingPercentile.enabled(對命令執行的延遲是否使用百分位數來跟蹤和計算)
      4. metrics.rollingPercentile.timeInMilliseconds(設置百分位統計的滾動窗口的持續時間)
      5. metrics.rollingPercentile.numBuckets(設置百分位統計滾動窗口中使用“桶”的數量)
      6. metrics.rollingPercentile.bucketSize(設置在執行過程中每個“桶”中保留的最大執行次數)
      7. metrics.healthSnapshot.intervalInMilliseconds(采集健康快照的間隔等待時間)
    5. Request Context
      1. requestCache.enabled(是否啟用緩存)
      2. requestLog.enabled(執行的時間是否打印到日志)
  2. Collapser Properties
    1. maxRequestsInBatch(請求合并批處理中允許的最大請求數)
    2. timerDelayInMilliseconds(批處理過程中每個命令延遲的時間,毫秒級)
    3. requestCache.enabled(是否開啟請求緩存)
  3. Thread Pool Properties
    1. coreSize(線程池大小)
    2. maxQueueSize(最大隊列數量)
    3. queueSizeRejectionThreshold (隊列大小拒絕閾值)
    4. metrics.rollingStats.timeInMilliseconds(滾動時間窗的長度,毫秒級)
    5. metrics.rollingStats.numBuckets(滾動時間窗被劃分的數量)

Github

https://github.com/XuePeng87/owl-bookstore

轉載于:https://my.oschina.net/u/2450666/blog/1499040

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/257828.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/257828.shtml
英文地址,請注明出處:http://en.pswp.cn/news/257828.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java反射機制的使用方法

Java的反射機制同意你在程序執行的過程中獲取類定義的細節。有時候在程序執行的時候才得知要調用哪個方法&#xff0c;這時候反射機制就派上用場了。獲取類 類的獲取方法有下面幾種&#xff1a;forName()。通過Class.forName()獲取與字符串向相應的類。比方\lstinline{Class.fo…

銀行計算機設備日常檢查表,[計算機]201154安全檢查表.doc

[計算機]201154安全檢查表土建基礎框架施工檢查表編號&#xff1a;2011-03-01-11工程名稱鑄造車間檢查時間2011 年 月 日檢查部位基礎施工檢 查 人檢 查結 論百分制折合分數&#xff1a;需要整改共 條。受檢單位河南周口受檢責任人檢 查 內 容檢查項目檢查內容和安全文明施工要…

我為什么要寫FansUnion個人官網-BriefCMS-電子商務malling等系統

不少朋友一直關注我最近幾個月&#xff0c;已經做的和正在做的項目&#xff0c;比如個人官網、BriefCMS、電子上午malling等系統。但是呢&#xff0c;部分朋友比較好奇&#xff0c;為啥要去寫。他們比較疑惑的是&#xff0c;市面上已經有很多類似的系統了&#xff0c;甚至有部分…

Node開發文件上傳系統及向七牛云存儲和亞馬遜AWS S3的文件上傳

背景起&#xff0c;有奏樂&#xff1a; 有偉人曰&#xff1a;學習技能的最好途徑莫過于理論與實踐相結合。 初學Node這貨時&#xff0c;每每讀教程必會Fall asleep。 當真要開發系統時&#xff0c;頓覺精神百倍&#xff0c;即便踩坑無數也不失斗志。 因為同團隊的小伙伴們都在辛…

計算機學業水平考試及格,信息技術學業水平考試表格部分試題(帶答案)

第三章表格信息的加工與表達復習學案【學習目標】1.熟練使用excel加工表格信息&#xff0c;理解用圖表來表現信息的特點與意義&#xff0c;2.能根據表格數據關系選擇合適的圖表類型表達意圖。【考點】1.表格中常用的函數及其求值方法&#xff1b;2.根據數據選擇合適的圖表類型&…

Ok6410掛載NFS

虛擬機&#xff1a; apt-get install portmap apt-get install nfs-kernel-server mkdir /nfs/root/mNFS chmod 777 /nfs chmod 777 /nfs/root vi /etc/exports 添加&#xff1a;/nfs/root *(rw,sync,no_root_squash) 開發板&#xff1a; mount -t nfs 192.168.0.12…

云計算:容器技術變革云計算,SaaS帶動CaaS市場

報告摘要&#xff1a; 1、容器技術增速驚人&#xff0c;市場認可度提高 虛擬化是云計算的重要基礎&#xff0c;Docker定義了一套容器從構建到執行的標準化體系&#xff0c;改變了傳統的虛擬化技術&#xff0c;深度影響了云計算領域。 隨著谷歌、亞馬遜、微軟等云計算廠商紛紛加…

Jan 12 - Delete Node in a Linked List; Data Structure; Linked List; Pointer;

代碼&#xff1a; /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val x; }* }*/ public class Solution {public void deleteNode(ListNode node) {if(node null) return;while(node.next ! …

三年級神奇電子計算機教案,人教版小學三年級下冊信息技術教案

人教版小學三年級下冊信息技術教案 人教版小學信息技術教案第一課 神奇的信息世界教學目的&#xff1a;通過學習使學生更充分地了解信息技術在生活中的應用。教學內容&#xff1a;觀看“神奇的信息世界”光碟教學準備&#xff1a;1、調試每臺計算機 2、打開計算機并由教師機控制…

spark 安裝配置

最佳參考鏈接 https://opensourceteam.gitbooks.io/bigdata/content/spark/install/spark-160-bin-hadoop26an_zhuang.html Apache Spark1.1.0部署與開發環境搭建   Spark是Apache公司推出的一種基于Hadoop Distributed File System(HDFS)的并行計算架構。與MapReduce不同&am…

《大數據原理:復雜信息的準備、共享和分析》一一2.5 在標識符中嵌入信息:不推薦...

2.5 在標識符中嵌入信息&#xff1a;不推薦大多數標識符不是純粹的隨機數&#xff0c;它們通常含有一些可由熟悉標識系統的人解釋的嵌入信息。例如&#xff0c;標識符中可以嵌入姓的前三個字母&#xff0c;同樣&#xff0c;標識符中也可以嵌入出生年份的最后兩位數字。標識符中…

python基礎知識-列表,元組,字典

列表&#xff08;list&#xff09; 賦值方法&#xff1a; l [11,45,67,34,89,23] l list() 列表的方法&#xff1a; 1 #!/usr/bin/env python2 3 class list(object):4 """5 list() -> new empty list6 list(iterable) -> new list initial…

車站計算機聯鎖系統的仿真設計,車站計算機聯鎖仿真設計.doc

車站計算機聯鎖仿真設計2012 屆 交通運輸 學院專 業學 號 2008學生姓名指導教師完成日期 2012年 月日計算機聯鎖是保證車站內列車和調車作業安全&#xff0c;提高車站通過能力的一種信號設備。設計以沙盤模型為根據&#xff0c;練習制作聯鎖信號圖表&#xff0c;使用Visual Bas…

如何解決機器學習中的數據不平衡問題?

在機器學習任務中&#xff0c;我們經常會遇到這種困擾&#xff1a;數據不平衡問題。 數據不平衡問題主要存在于有監督機器學習任務中。當遇到不平衡數據時&#xff0c;以總體分類準確率為學習目標的傳統分類算法會過多地關注多數類&#xff0c;從而使得少數類樣本的分類性能下降…

ubuntu每次登陸都用root賬號登陸

sudo -s 進入 root 用戶權限模式 vi /etc/lightdm/lightdm.conf [SeatDefaults] greeter-sessionunity-greeter user-sessionUbuntu greeter-show-manual-logintrue allow-guestfasle 重啟后再登陸就會 直接用root登陸了 版權聲明&#xff1a;本文為博主原創文章&#xff0c;未…

js-BOM

私有變量&#xff1a; 1、在一個實例上調用setName&#xff08;&#xff09;會影響所有的實例 BOM&#xff1a; 1、全局變量不能通過delete操作符刪除&#xff0c;而直接在window對象上定義的屬性可以 2、嘗試訪問為聲明的變量會拋出錯誤&#xff0c;但通過查詢window對象&…

計算機組成實驗v代表什么,2014計算機組成原理實驗指導V1.3.docx

文檔介紹&#xff1a;實驗一運算器組成實驗實驗目的熟悉Logisim軟件平臺。掌握運算器基本工作原理掌握運算溢出檢測的原理和實現方法;理解有符號數和無符號數運算的區別;理解基于補碼的加/減運算實現原理;熟悉運算器的數據傳輸通路。實驗環境Logisim是一款數字電路模擬的教育軟…

四大技巧輕松搞定云容器

云容器技術&#xff0c;作為傳統虛擬化管理程序的一種替代品&#xff0c;正稱霸著云市場。容器是輕量級的&#xff0c;并提供增強的便攜性&#xff0c;允許應用在平臺之間遷移&#xff0c;而不需要開發者重做或重新架構應用。但是&#xff0c;盡管其好處讓開發人員感到驚嘆&…

Android 圖文混排 通過webview實現并實現點擊圖片

在一個開源項目看到是用的webview 實現的 1. 這是在asset中的一個模板html <html> <head> <title>News Detail</title> <meta name"viewport" content"widthdevice-width, minimum-scale0.5, initial-scale1.2, maximum-scale2.0…

h5engine造輪子

基于學習的造輪子&#xff0c;這是一個最簡單&#xff0c;最基礎的一個canvas渲染引擎&#xff0c;通過這個引擎架構&#xff0c;可以很快的學習canvas渲染模式&#xff01; 地址&#xff1a;https://github.com/RichLiu1023/h5engine 這是一個比較有意思的h5渲染引擎&#xff…