javascript
SpringCloud微服务(03):Hystrix组件,实现服务熔断
寫在前面:閱讀本文前,你可能需要熟悉一下內容。
微服務組件:Eureka管理注冊中心
微服務組件:Ribbon和Feign服務調用
SpringBoot系統異常映射處理
一、熔斷器簡介
微服務架構特點就是多服務,多數據源,支撐系統應用。這樣導致微服務之間存在依賴關系。如果其中一個服務故障,可能導致系統宕機,這就是所謂的雪崩效應。
1、服務熔斷
微服務架構中某個微服務發生故障時,要快速切斷服務,提示用戶,后續請求,不調用該服務,直接返回,釋放資源,這就是服務熔斷。
熔斷生效后,會在指定的時間后調用請求來測試依賴是否恢復,依賴的應用恢復后關閉熔斷。
2、服務降級
服務器高并發下,壓力劇增的時候,根據當業務情況以及流量,對一些服務和頁面有策略的降級(可以理解為關閉不必要的服務),以此緩解服務器資源的壓力以保障核心任務的正常運行。
雙十一期間,支付寶很多功能都會提示,[雙十一期間,保障核心交易,某某服務數據延遲]。
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、熔斷執行方法
/*** 服務熔斷調用方法*/ public String getDefaultInfo (){return "服務被熔斷" ; }2、簡單案例
/*** 簡單配置*/ @RequestMapping("/showInfo1") @HystrixCommand(fallbackMethod = "getDefaultInfo") public String showInfo1 (){return restTemplate.getForObject(server_name+"/getInfo",String.class) ; }Hystrix默認的超時時間是1秒,超時時間內部響應,就會執行熔斷,進入fallback程序。由于Spring的懶加載機制,首次請求往往比較慢,可以通過配置Hystrix超時時間解決。
3、復雜案例
- 配置超時、并發、線程池、指定異常熔斷忽略
4、啟動類注解
- @EnableHystrix
三、基于Feign服務熔斷
1、Jar包說明
通過觀察Fegin依賴的JAR可知,Fegin的Jar下包含Hystrix需要的Jar包,這里不用再次導入依賴。
2、熔斷配置
Feign用接口實現的聲明式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)、熔斷執行代碼
@Component public class FallbackService implements GetAuthorService {@Overridepublic String getAuthorInfo(String authorId) {return "服務被熔斷"+authorId;} }3)、配置文件
- 開啟熔斷功能
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 碼云地址:知了一笑 https://gitee.com/cicadasmile
總結
以上是生活随笔為你收集整理的SpringCloud微服务(03):Hystrix组件,实现服务熔断的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HDU-2079 选课时间(题目已修改,
- 下一篇: PIX初级配置教程