什么是Spring Cloud Hystrix 雅采?
在微服務架構中爵憎,我們將系統(tǒng)拆分成了一個個的服務單元,各單元應用間通過服務注冊與訂閱的方式互相依賴婚瓜。由于每個單元都在不同的進程中運行宝鼓,依賴通過遠程調用的方式執(zhí)行,這樣就有可能因為網絡原因或是依賴服務自身問題出現(xiàn)調用故障或延遲闰渔,而這些問題會直接導致調用方的對外服務也出現(xiàn)延遲席函,若此時調用方的請求不斷增加铐望,最后就會出現(xiàn)因等待出現(xiàn)故障的依賴方響應而形成任務積壓冈涧,線程資源無法釋放,最終導致自身服務的癱瘓正蛙,進一步甚至出現(xiàn)故障的蔓延最終導致整個系統(tǒng)的癱瘓督弓。如果這樣的架構存在如此嚴重的隱患,那么相較傳統(tǒng)架構就更加的不穩(wěn)定乒验。為了解決這樣的問題愚隧,因此產生了斷路器等一系列的服務保護機制。
針對上述問題锻全,在Spring Cloud Hystrix中實現(xiàn)了線程隔離狂塘、斷路器等一系列的服務保護功能录煤。它也是基于Netflix的開源框架 Hystrix實現(xiàn)的,該框架目標在于通過控制那些訪問遠程系統(tǒng)荞胡、服務和第三方庫的節(jié)點妈踊,從而對延遲和故障提供更強大的容錯能力。Hystrix具備了服務降級泪漂、服務熔斷廊营、線程隔離、請求緩存萝勤、請求合并以及服務監(jiān)控等強大功能露筒。
準備工作:
搭建 服務注冊中心,
發(fā)布 務提供者敌卓。
新建spring boot 項目
修改pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>chanzj</groupId>
<artifactId>eureka-consumer-ribbon</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>eureka-consumer-ribbon</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<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.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Dalston.SR1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
在應用主類中使用@EnableCircuitBreaker或@EnableHystrix注解開啟Hystrix的使用:
package chanzj.eurekaconsumerribbon;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@EnableCircuitBreaker
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaConsumerRibbonApplication {
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(EurekaConsumerRibbonApplication.class, args);
}
}
新建Service慎式,在為具體執(zhí)行邏輯的函數(shù)上增加@HystrixCommand注解來指定服務降級方法
package chanzj.eurekaconsumerribbon.service;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;
@Service
public class RibbonService {
@Autowired
RestTemplate restTemplate;
@HystrixCommand(fallbackMethod = "fallback")
public String consumer(){
return restTemplate.getForObject("http://eureka-client/test", String.class);
}
public String fallback(){
return "fallback";
}
}
在Controller里調用方法:
package chanzj.eurekaconsumerribbon.web;
import chanzj.eurekaconsumerribbon.service.RibbonService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class RibbonController {
@Autowired
RibbonService ribbonService;
@GetMapping("/test")
public String test() {
return ribbonService.consumer();
}
}
最后在服務提供端加上延遲時間制造訪問超時,發(fā)布所有服務假哎,
訪問 http://localhost:2105/test
訪問超時的方法瞬捕。
好!結束舵抹!