激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - Java教程 - 詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

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

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

一:什么是hystrix

在分布式環(huán)境中,許多服務(wù)依賴項(xiàng)中的一些將不可避免地失敗。hystrix是一個(gè)庫,通過添加延遲容差和容錯(cuò)邏輯來幫助您控制這些分布式服務(wù)之間的交互。hystrix通過隔離服務(wù)之間的訪問點(diǎn),停止其間的級(jí)聯(lián)故障以及提供回退選項(xiàng),從而提高系統(tǒng)的整體彈性。

hystrix旨在執(zhí)行以下操作

1:對(duì)通過第三方客戶端庫訪問(通常通過網(wǎng)絡(luò))的依賴關(guān)系提供保護(hù)并控制延遲和故障。

2:隔離復(fù)雜分布式系統(tǒng)中的級(jí)聯(lián)故障。

3:快速發(fā)現(xiàn)故障,盡快恢復(fù)。

4:回退,盡可能優(yōu)雅地降級(jí)。

5:啟用近實(shí)時(shí)監(jiān)控,警報(bào)和操作控制。

二:為什么需要hystrix?

大型分布式系統(tǒng)中,一個(gè)客戶端或者服務(wù)依賴外部服務(wù),如果一個(gè)服務(wù)宕了,那么由于我們?cè)O(shè)置了服務(wù)調(diào)用系統(tǒng)超時(shí)時(shí)間,勢必會(huì)影響相應(yīng)時(shí)間,在高并發(fā)的情況下大多數(shù)服務(wù)器的線程池就出現(xiàn)阻塞(block),影響整個(gè)線上服務(wù)的穩(wěn)定性。

(圖片官方圖片)

當(dāng)一切都健康時(shí),請(qǐng)求可以看起來像這樣

詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

當(dāng)許多后端服務(wù)系統(tǒng)中的一個(gè)宕掉時(shí),整個(gè)用戶請(qǐng)求:

詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

如果多個(gè)客戶端調(diào)用同一個(gè)異常服務(wù)的時(shí)候,出現(xiàn)的情況是:

詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

三:hystrix解決什么問題?

分布式架構(gòu)中的應(yīng)用程序具有幾十個(gè)依賴關(guān)系,每個(gè)依賴關(guān)系在某個(gè)時(shí)刻將不可避免的出現(xiàn)異常。如果應(yīng)用程序不與這些外部故障隔離,則可能出現(xiàn)線程池阻塞,引起系統(tǒng)雪崩。

例如,對(duì)于依賴30個(gè)服務(wù)的應(yīng)用程序,每個(gè)服務(wù)的正常運(yùn)行時(shí)間為99.99%,您可以:

99.99%的30次方 = 99.7%正常運(yùn)行時(shí)間

0.3%的10億次請(qǐng)求= 3,000,000次故障

2+小時(shí)宕機(jī)/月,即使所有依賴關(guān)系正常運(yùn)行時(shí)間。

當(dāng)使用hystrix進(jìn)行熔斷后,每個(gè)依賴關(guān)系彼此隔離了,限制了當(dāng)發(fā)生延遲時(shí)的阻塞。

詳解SpringCloud微服務(wù)架構(gòu)之Hystrix斷路器

四:hystrix結(jié)合feign使用

創(chuàng)建一個(gè)工程eureka_feign_hystrix_client

pom.xml文件內(nèi)容

?
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>

創(chuàng)建啟動(dòng)文件

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();
}

創(chuàng)建熔斷類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() 服務(wù)不可用。。");
 
  }
 
  @override
  public string getuserinfostr() {
    return " userclienthystrix getuserinfostr() is fallback 服務(wù)不可用。。";
 
  }
 
  @override
  public string info() {
    return " userclienthystrix info() is fallback 服務(wù)不可用。。";
 
  }
}

當(dāng)網(wǎng)絡(luò)出現(xiàn)異常的時(shí)候或直接跳轉(zhuǎn)到這里實(shí)現(xiàn)類里面

創(chuàng)建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();
  }

先啟動(dòng):eureka_register_service(注冊(cè)中心)工程

然后運(yùn)行我們寫好的feignhystrixapplication

這個(gè)時(shí)候我們明顯發(fā)現(xiàn)沒有運(yùn)行biz-service-0 服務(wù),那么我們 打開

出現(xiàn)

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

這個(gè)就是我們自定義的熔斷返回結(jié)果

如果不用熔斷 頁面會(huì)出現(xiàn)這個(gè)

?
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相關(guān)原理,由于沒有全部看完所以暫時(shí)沒有寫上去,本文是結(jié)合feign使用和學(xué)習(xí)。

有興起的可以看下官方的hystrix很詳細(xì),就是看起來有點(diǎn)費(fèi)勁,

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 中文字幕爱爱视频 | 亚洲3atv精品一区二区三区 | 久久久一区二区 | 97中文字幕在线观看 | 一级做a爰片性色毛片2021 | 欧美精品一区自拍a毛片在线视频 | 久久精品视频亚洲 | 欧美成人自拍 | 久久人人爽人人爽人人片av免费 | 一本色道久久综合亚洲精品小说 | 九九热欧美 | 九九热精| 色奇米 | 宅男视频在线观看免费 | 国产88久久久国产精品免费二区 | 精品国产一区二区三区四区在线 | 永久免费在线观看av | 国产宾馆3p国语对白 | 国产一区日韩精品 | 日韩伦理电影免费观看 | 欧美黄一级| 视频一区免费观看 | 成人在线视频免费 | 高清国产午夜精品久久久久久 | 国产无遮挡一区二区三区毛片日本 | 毛片电影网址 | 日本成年网 | 国产69精品久久久久久 | 免费观看国产视频 | 奇米影视8888狠狠狠狠 | 国产99久久精品一区二区 | japanese javhd| 日本68xxxx | 亚洲情av| 欧美成人黄色小视频 | 成人av一区二区免费播放 | 亚洲精品无码不卡在线播放he | av日韩在线免费观看 | 日日噜噜噜夜夜狠狠久久蜜桃 | 成人在线观看污 | 国产99精品视频 |