欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年08月02日 08:54:17   作者:知了一笑  
微服務架構特點就是多服務,多數(shù)據(jù)源,支撐系統(tǒng)應用。這樣導致微服務之間存在依賴關系。這篇文章主要介紹了SpringCloud微服務之Hystrix組件實現(xiàn)服務熔斷的方法,需要的朋友可以參考下

一、熔斷器簡介

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

1、服務熔斷

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

熔斷生效后,會在指定的時間后調(diào)用請求來測試依賴是否恢復,依賴的應用恢復后關閉熔斷。

2、服務降級

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

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

3、核心依賴

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

4、核心注解

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

5、案例模塊描述

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

二、基于Ribbon服務熔斷

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

/**
 * 服務熔斷調(diào)用方法
 */
public String getDefaultInfo (){
  return "服務被熔斷" ;
}

2、簡單案例

/**
 * 簡單配置
 */
@RequestMapping("/showInfo1")
@HystrixCommand(fallbackMethod = "getDefaultInfo")
public String showInfo1 (){
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

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

3、復雜案例

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

/**
 * 復雜配置
 */
@RequestMapping("/showInfo2")
@HystrixCommand(
    fallbackMethod = "getDefaultInfo",
    commandProperties={
        // 降級處理超時時間設置
        @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),
        // 任意時間點允許的最高并發(fā)數(shù)。超過該設置值后,拒絕執(zhí)行請求。
        @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 = "" ;
  // 測試配置異常不熔斷
  // 響應:{"code":500,"msg":"運行異常"}
  if (value.equals("")){
    throw new ServiceException("運行異常") ;
  }
  // 該異常被熔斷
  // if (value.equals("")){
  //   throw new RuntimeException("拋出錯誤") ;
  // }
  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}

4、啟動類注解

•@EnableHystrix

三、基于Feign服務熔斷

1、Jar包說明

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

2、熔斷配置

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

1)、接口代碼

@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í)行代碼

@Component
public class FallbackService implements GetAuthorService {
  @Override
  public String getAuthorInfo(String authorId) {
    return "服務被熔斷"+authorId;
  }
}

3)、配置文件

•開啟熔斷功能

feign:
 hystrix:
  enabled: true

3、服務類注解

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

@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"})
@EnableEurekaClient  // 本服務啟動后會自動注冊進eureka服務中
@EnableDiscoveryClient
// 因為包名路徑不同,需要加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

總結

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

相關文章

  • 詳解Java 中的UnitTest 和 PowerMock

    詳解Java 中的UnitTest 和 PowerMock

    這篇文章主要介紹了Java中的 UnitTest 和 PowerMock,文中講解非常詳細,對大家學習有很大的幫助,感興趣的朋友可以了解下
    2020-06-06
  • 解決@RequestBody搭配@Data的大坑

    解決@RequestBody搭配@Data的大坑

    這篇文章主要介紹了解決@RequestBody搭配@Data的大坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Javaweb獲取表單數(shù)據(jù)的多種方式

    Javaweb獲取表單數(shù)據(jù)的多種方式

    這篇文章主要為大家詳細介紹了Javaweb獲取表單數(shù)據(jù)的多種方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JAVA構造函數(shù)(方法)示例詳解

    JAVA構造函數(shù)(方法)示例詳解

    構造函數(shù),是一種特殊的方法,主要用來在創(chuàng)建對象時初始化對象,即為對象成員變量賦初始值,總與new運算符一起使用在創(chuàng)建對象的語句中,這篇文章主要給大家介紹了關于JAVA構造函數(shù)(方法)的相關資料,需要的朋友可以參考下
    2021-11-11
  • Spring Boot實現(xiàn)異步請求(Servlet 3.0)

    Spring Boot實現(xiàn)異步請求(Servlet 3.0)

    在spring 3.2 及以后版本中增加了對請求的異步處理,這篇文章主要介紹了Spring Boot實現(xiàn)異步請求(Servlet 3.0),感興趣的小伙伴們可以參考一下。
    2017-04-04
  • java實現(xiàn)停車場系統(tǒng)

    java實現(xiàn)停車場系統(tǒng)

    這篇文章主要為大家詳細介紹了java實現(xiàn)停車場系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • struts2靜態(tài)資源映射代碼示例

    struts2靜態(tài)資源映射代碼示例

    這篇文章主要介紹了struts2靜態(tài)資源映射的相關內(nèi)容,涉及了具體代碼示例,具有一定參考價值,需要的朋友可以了解下。
    2017-09-09
  • 如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解

    如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解

    這篇文章主要介紹了如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 解決@JsonInclude(JsonInclude.Include.NON_NULL)不起作用問題

    解決@JsonInclude(JsonInclude.Include.NON_NULL)不起作用問題

    這篇文章主要介紹了解決@JsonInclude(JsonInclude.Include.NON_NULL)不起作用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 關于@Value注入List,Map及設置默認值問題

    關于@Value注入List,Map及設置默認值問題

    這篇文章主要介紹了@Value注入List,Map及設置默認值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05

最新評論