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

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

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

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - SpringCloud微服務(wù)之Hystrix組件實(shí)現(xiàn)服務(wù)熔斷的方法

SpringCloud微服務(wù)之Hystrix組件實(shí)現(xiàn)服務(wù)熔斷的方法

2021-09-08 10:17知了一笑 Java教程

微服務(wù)架構(gòu)特點(diǎn)就是多服務(wù),多數(shù)據(jù)源,支撐系統(tǒng)應(yīng)用。這樣導(dǎo)致微服務(wù)之間存在依賴關(guān)系。這篇文章主要介紹了SpringCloud微服務(wù)之Hystrix組件實(shí)現(xiàn)服務(wù)熔斷的方法,需要的朋友可以參考下

一、熔斷器簡(jiǎn)介

服務(wù)架構(gòu)特點(diǎn)就是多服務(wù),多數(shù)據(jù)源,支撐系統(tǒng)應(yīng)用。這樣導(dǎo)致微服務(wù)之間存在依賴關(guān)系。如果其中一個(gè)服務(wù)故障,可能導(dǎo)致系統(tǒng)宕機(jī),這就是所謂的雪崩效應(yīng)。

1、服務(wù)熔斷

微服務(wù)架構(gòu)中某個(gè)微服務(wù)發(fā)生故障時(shí),要快速切斷服務(wù),提示用戶,后續(xù)請(qǐng)求,不調(diào)用該服務(wù),直接返回,釋放資源,這就是服務(wù)熔斷。

熔斷生效后,會(huì)在指定的時(shí)間后調(diào)用請(qǐng)求來測(cè)試依賴是否恢復(fù),依賴的應(yīng)用恢復(fù)后關(guān)閉熔斷。

2、服務(wù)降級(jí)

服務(wù)器高并發(fā)下,壓力劇增的時(shí)候,根據(jù)當(dāng)業(yè)務(wù)情況以及流量,對(duì)一些服務(wù)和頁(yè)面有策略的降級(jí)(可以理解為關(guān)閉不必要的服務(wù)),以此緩解服務(wù)器資源的壓力以保障核心任務(wù)的正常運(yùn)行。

雙十一期間,支付寶很多功能都會(huì)提示,[雙十一期間,保障核心交易,某某服務(wù)數(shù)據(jù)延遲]。

3、核心依賴

?
1
2
3
4
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>

4、核心注解

•@EnableHystrix 啟動(dòng)類注解控制熔斷功能。
•@HystrixCommand 方法注解,熔斷控制配置。

5、案例模塊描述

演示基于Ribbon服務(wù)的熔斷
node03-consume-8001
演示基于Feign服務(wù)的熔斷
node03-consume-8002
Eureka注冊(cè)中心
node03-eureka-7001
兩個(gè)服務(wù)提供方
node03-provider-6001
node03-provider-6002

二、基于Ribbon服務(wù)熔斷

1、熔斷執(zhí)行方法

?
1
2
3
4
5
6
/**
 * 服務(wù)熔斷調(diào)用方法
 */
public String getDefaultInfo (){
  return "服務(wù)被熔斷" ;
}

2、簡(jiǎn)單案例

?
1
2
3
4
5
6
7
8
/**
 * 簡(jiǎn)單配置
 */
@RequestMapping("/showInfo1")
@HystrixCommand(fallbackMethod = "getDefaultInfo")
public String showInfo1 (){
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

Hystrix默認(rèn)的超時(shí)時(shí)間是1秒,超時(shí)時(shí)間內(nèi)部響應(yīng),就會(huì)執(zhí)行熔斷,進(jìn)入fallback程序。由于Spring的懶加載機(jī)制,首次請(qǐng)求往往比較慢,可以通過配置Hystrix超時(shí)時(shí)間解決。

3、復(fù)雜案例

•配置超時(shí)、并發(fā)、線程池、指定異常熔斷忽略

?
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
/**
 * 復(fù)雜配置
 */
@RequestMapping("/showInfo2")
@HystrixCommand(
    fallbackMethod = "getDefaultInfo",
    commandProperties={
        // 降級(jí)處理超時(shí)時(shí)間設(shè)置
        @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),
        // 任意時(shí)間點(diǎn)允許的最高并發(fā)數(shù)。超過該設(shè)置值后,拒絕執(zhí)行請(qǐng)求。
        @HystrixProperty(name = "fallback.isolation.semaphore.maxConcurrentRequests", value = "1000"),
    },
    // 配置執(zhí)行的線城池
    threadPoolProperties = {
        @HystrixProperty(name = "coreSize", value = "20"),
        @HystrixProperty(name = "maxQueueSize", value = "-1"),
    },
    // 該異常不執(zhí)行熔斷,去執(zhí)行該異常拋出的自己邏輯
    ignoreExceptions = {ServiceException.class}
)
public String showInfo2 (){
  String value = "" ;
  // 測(cè)試配置異常不熔斷
  // 響應(yīng):{"code":500,"msg":"運(yùn)行異常"}
  if (value.equals("")){
    throw new ServiceException("運(yùn)行異常") ;
  }
  // 該異常被熔斷
  // if (value.equals("")){
  //   throw new RuntimeException("拋出錯(cuò)誤") ;
  // }
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

4、啟動(dòng)類注解

•@EnableHystrix

三、基于Feign服務(wù)熔斷

1、Jar包說明

通過觀察Fegin依賴的JAR可知,F(xiàn)egin的Jar下包含Hystrix需要的Jar包,這里不用再次導(dǎo)入依賴。

2、熔斷配置

Feign用接口實(shí)現(xiàn)的聲明式Rest請(qǐng)求,所以配置也就在接口上面了。

1)、接口代碼

?
1
2
3
4
5
@FeignClient(value = "NODE02-PROVIDER",fallback = FallbackService.class)
public interface GetAuthorService {
  @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET)
  String getAuthorInfo (@PathVariable("authorId") String authorId) ;
}

2)、熔斷執(zhí)行代碼

?
1
2
3
4
5
6
7
@Component
public class FallbackService implements GetAuthorService {
  @Override
  public String getAuthorInfo(String authorId) {
    return "服務(wù)被熔斷"+authorId;
  }
}

3)、配置文件

•開啟熔斷功能

?
1
2
3
feign:
 hystrix:
  enabled: true

3、服務(wù)類注解

由于上面的接口和熔斷代碼是在不同的Jar模塊中,所以要在啟動(dòng)類@SpringBootApplication注解中掃描,如下。

?
1
2
3
4
5
6
7
8
9
10
@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"})
@EnableEurekaClient  // 本服務(wù)啟動(dòng)后會(huì)自動(dòng)注冊(cè)進(jìn)eureka服務(wù)中
@EnableDiscoveryClient
// 因?yàn)榘窂讲煌?,需要加basePackages屬性
@EnableFeignClients(basePackages={"cloud.block.code.service"})
public class Application_8002 {
  public static void main(String[] args) {
    SpringApplication.run(Application_8002.class,args) ;
  }
}

四、源代碼說明

GitHub地址:知了一笑
https://github.com/cicadasmile/spring-cloud-base
碼云地址:知了一笑
https://gitee.com/cicadasmile/spring-cloud-base

總結(jié)

以上所述是小編給大家介紹的SpringCloud微服務(wù)之Hystrix組件實(shí)現(xiàn)服務(wù)熔斷的方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

原文鏈接:https://www.cnblogs.com/cicada-smile/archive/2019/08/02/11286451.html

延伸 · 閱讀

精彩推薦
  • Java教程Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java8中Stream使用的一個(gè)注意事項(xiàng)

    Java8中Stream使用的一個(gè)注意事項(xiàng)

    最近在工作中發(fā)現(xiàn)了對(duì)于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個(gè)非常重要的注意點(diǎn),所以這篇文章主要給大家介紹了關(guān)于Java8中S...

    阿杜7472021-02-04
  • Java教程Java實(shí)現(xiàn)搶紅包功能

    Java實(shí)現(xiàn)搶紅包功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)搶紅包功能,采用多線程模擬多人同時(shí)搶紅包,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程xml與Java對(duì)象的轉(zhuǎn)換詳解

    xml與Java對(duì)象的轉(zhuǎn)換詳解

    這篇文章主要介紹了xml與Java對(duì)象的轉(zhuǎn)換詳解的相關(guān)資料,需要的朋友可以參考下...

    Java教程網(wǎng)2942020-09-17
  • Java教程升級(jí)IDEA后Lombok不能使用的解決方法

    升級(jí)IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級(jí),尋思已經(jīng)有好久沒有升過級(jí)了。升級(jí)完畢重啟之后,突然發(fā)現(xiàn)好多錯(cuò)誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關(guān)于小米推送Java代碼,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧...

    富貴穩(wěn)中求8032021-07-12
  • Java教程20個(gè)非常實(shí)用的Java程序代碼片段

    20個(gè)非常實(shí)用的Java程序代碼片段

    這篇文章主要為大家分享了20個(gè)非常實(shí)用的Java程序片段,對(duì)java開發(fā)項(xiàng)目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 欧美国产日韩综合 | 国产精品免费综合一区视频 | 第一国内永久免费福利视频 | 国产欧美一区二区三区免费 | 青青视频国产依人在线 | 欧美成人福利视频 | 亚洲福利区 | 美女被扒开屁股进去网 | 亚洲色大成网站www久久九九 | 国产免费小视频在线观看 | 亚洲国产区男人本色在线观看欧美 | 无限资源在线观看完整版免费下载 | 国产东北三老头伦一肥婆 | 嗯啊在线观看免费影院 | 糖心vlog麻豆精东影业传媒 | 91制片厂制作传媒免费版樱花 | 好大好硬好湿好紧h | 91aaa免费免费国产在线观看 | 村妇超级乱淫伦小说全集 | 午夜影院一区二区三区 | bdsm酷刑折磨死美女 | 欧美成人福利视频 | 国内精品一区视频在线播放 | 免费看国产精品久久久久 | 无码国产成人午夜在线观看不卡 | 狠狠香蕉 | 久久国产加勒比精品无码 | 国产伦久视频免费观看视频 | 亚洲第一福利网 | 精品伊人 | 俄罗斯一级毛片免费播放 | 国产免费不卡视频 | 国产三级自拍 | 麻豆视频免费在线观看 | 欧美日韩国产一区二区三区伦 | 丰满艳妇亲伦视频 | 叛佛 作者满栀小说免费阅读 | 8mav福利视频| 男女男精品视频 | 激情综合 | xxxx意大利xxxxhd |