一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 詳解SpringCloud微服務架構之Hystrix斷路器

詳解SpringCloud微服務架構之Hystrix斷路器

2021-03-17 14:40Bob_F Java教程

本篇文章主要介紹了詳解SpringCloud微服務架構之Hystrix斷路器,Hystrix是一個庫,通過添加延遲容差和容錯邏輯來幫助您控制這些分布式服務之間的交互,有興趣的可以了解一下

一:什么是hystrix

在分布式環境中,許多服務依賴項中的一些將不可避免地失敗。hystrix是一個庫,通過添加延遲容差和容錯邏輯來幫助您控制這些分布式服務之間的交互。hystrix通過隔離服務之間的訪問點,停止其間的級聯故障以及提供回退選項,從而提高系統的整體彈性。

hystrix旨在執行以下操作

1:對通過第三方客戶端庫訪問(通常通過網絡)的依賴關系提供保護并控制延遲和故障。

2:隔離復雜分布式系統中的級聯故障。

3:快速發現故障,盡快恢復。

4:回退,盡可能優雅地降級。

5:啟用近實時監控,警報和操作控制。

二:為什么需要hystrix?

大型分布式系統中,一個客戶端或者服務依賴外部服務,如果一個服務宕了,那么由于我們設置了服務調用系統超時時間,勢必會影響相應時間,在高并發的情況下大多數服務器的線程池就出現阻塞(block),影響整個線上服務的穩定性。

(圖片官方圖片)

當一切都健康時,請求可以看起來像這樣

詳解SpringCloud微服務架構之Hystrix斷路器

當許多后端服務系統中的一個宕掉時,整個用戶請求:

詳解SpringCloud微服務架構之Hystrix斷路器

如果多個客戶端調用同一個異常服務的時候,出現的情況是:

詳解SpringCloud微服務架構之Hystrix斷路器

三:hystrix解決什么問題?

分布式架構中的應用程序具有幾十個依賴關系,每個依賴關系在某個時刻將不可避免的出現異常。如果應用程序不與這些外部故障隔離,則可能出現線程池阻塞,引起系統雪崩。

例如,對于依賴30個服務的應用程序,每個服務的正常運行時間為99.99%,您可以:

99.99%的30次方 = 99.7%正常運行時間

0.3%的10億次請求= 3,000,000次故障

2+小時宕機/月,即使所有依賴關系正常運行時間。

當使用hystrix進行熔斷后,每個依賴關系彼此隔離了,限制了當發生延遲時的阻塞。

詳解SpringCloud微服務架構之Hystrix斷路器

四:hystrix結合feign使用

創建一個工程eureka_feign_hystrix_client

pom.xml文件內容

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<dependencies>
 
    <dependency>
 
      <groupid>org.springframework.cloud</groupid>
 
      <artifactid>spring-cloud-starter-feign</artifactid>
 
    </dependency>
 
    <dependency>
 
      <groupid>org.springframework.cloud</groupid>
 
      <artifactid>spring-cloud-starter-eureka</artifactid>
 
    </dependency>
 
    <dependency>
 
      <groupid>org.springframework.boot</groupid>
 
      <artifactid>spring-boot-starter-web</artifactid>
 
    </dependency>
 
    <dependency>
 
      <groupid>org.springframework.boot</groupid>
 
      <artifactid>spring-boot-starter-actuator</artifactid>
 
    </dependency>
 
    <dependency>
 
      <groupid>org.springframework.boot</groupid>
 
      <artifactid>spring-boot-starter-test</artifactid>
 
      <scope>test</scope>
 
    </dependency>
 
  </dependencies>
 
  <dependencymanagement>
 
    <dependencies>
 
      <dependency>
 
        <groupid>org.springframework.cloud</groupid>
 
        <artifactid>spring-cloud-dependencies</artifactid>
 
        <version>brixton.sr5</version>
 
        <type>pom</type>
 
        <scope>import</scope>
 
      </dependency>
 
    </dependencies>
 
  </dependencymanagement>

創建啟動文件

feignhystrixapplication

?
1
2
3
4
5
6
7
8
9
@springbootapplication
@enablediscoveryclient
@enablefeignclients
public class feignhystrixapplication {
  public static void main(string[] args) {
 
    springapplication.run(feignhystrixapplication.class, args);
  }
}

userclient類

?
1
2
3
4
5
6
7
8
9
@feignclient(value = "biz-service-0",fallback = userclienthystrix.class)
public interface userclient {
  @requestmapping(method = requestmethod.get, value = "/getuser")
  public user getuserinfo();
  @requestmapping(method = requestmethod.get, value = "/getuser")
  public string getuserinfostr();
  @requestmapping(method = requestmethod.get, value = "/info")
  public string info();
}

創建熔斷類userclienthystrix

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
@service
public class userclienthystrix implements userclient {
 
   @override
  public user getuserinfo() {
    throw new nullpointerexception(" user getuserinfo() 服務不可用。。");
 
  }
 
  @override
  public string getuserinfostr() {
    return " userclienthystrix getuserinfostr() is fallback 服務不可用。。";
 
  }
 
  @override
  public string info() {
    return " userclienthystrix info() is fallback 服務不可用。。";
 
  }
}

當網絡出現異常的時候或直接跳轉到這里實現類里面

創建action類

usercontroller

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@autowired
  userclient userclient;
 
  @requestmapping(value = "/getuserinfo", method = requestmethod.get)
  public user getuserinfo() {
    return userclient.getuserinfo();
  }
 
  @requestmapping(value = "/getuserinfostr", method = requestmethod.get)
  public string getuserinfostr() {
    return userclient.getuserinfostr();
  }
 
  @requestmapping(value = "/info", method = requestmethod.get)
  public string info() {
    return userclient.info();
  }

先啟動:eureka_register_service(注冊中心)工程

然后運行我們寫好的feignhystrixapplication

這個時候我們明顯發現沒有運行biz-service-0 服務,那么我們 打開

出現

userclienthystrix getuserinfostr() is fallback 服務不可用。。

這個就是我們自定義的熔斷返回結果

如果不用熔斷 頁面會出現這個

?
1
2
3
4
5
6
7
8
9
whitelabel error page
 
this application has no explicit mapping for /error, so you are seeing this as a fallback.
 
wed mar 22 14:32:21 cst 2017
 
there was an unexpected error (type=internal server error, status=500).
 
getuserinfo failed and fallback failed.

代碼地址:https://github.com/zhp8341/springclouddemo

本人也看了一些hystrix相關原理,由于沒有全部看完所以暫時沒有寫上去,本文是結合feign使用和學習。

有興起的可以看下官方的hystrix很詳細,就是看起來有點費勁,

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

原文鏈接:http://www.cnblogs.com/xiaojunbo/p/7094438.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产日产欧产精品精品软件 | 国产视频一区二区 | 亚洲久草视频 | 羞羞色男人的天堂伊人久久 | 香蕉视频在线观看网站 | 国产1区2区三区不卡 | 色天天综合网色鬼综合 | 日韩国产欧美视频 | 国产日日操| free嫩白的12sex性自由 | 青青网 | 女教师波多野结衣高清在线 | 五月激情丁香婷婷综合第九 | 白丝超短裙被输出娇喘不停小说 | 激情视频图片小说qvdo | 日韩在线视频在线 | 2019年国产高清情侣视频 | av中文字幕在线 | 美女靠逼免费网站 | 精品久久久久久无码人妻国产馆 | 男女一级特黄a大片 | 日韩国产成人资源精品视频 | 日韩欧美a | 四虎影视免费观看 | 久久草福利自拍视频在线观看 | 久久水蜜桃亚洲AV无码精品偷窥 | 我与恶魔的h生活ova | 亚洲精品资源在线 | 热99这里有精品综合久久 | 欧美视频在线播放观看免费福利资源 | 忘忧草在线社区WWW日本直播 | 动漫美女人物被黄漫小说 | 欧美人人干 | 九哥草逼网 | 精品久久久久久久久免费影院 | 闺蜜的样子小说安沁在线阅读 | 日韩欧美天堂 | 日本人作爰啪啪全过程 | 男生操男生 | 久久婷婷五月免费综合色啪 | 无遮挡免费h肉动漫在线观看 |