- 服务熔断
概念:微服务中,熔断机制是应对雪崩效应的一种微服务链路保护机制。当扇出链路的某个微服务不可用或者响应时间太长时,会进行服务降级,进而熔断该节点微服务的调用,快速返回“错误”的响应信息。当检测到该节点微服务调用响应正常后恢复调用链路。
服务熔断的作用类似于我们家用的保险丝,当某服务出现不可用或响应超时的情况时,为了防止整个系统出现雪崩,暂时停止对该服务的调用。
服务熔断是在服务端进行配置的,配置如下:
在pom.xml引入hystrix依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
在方法上添加注解@HystrixCommand(),以及fallback方法
@GetMapping(value="/dept/get/{id}")
@HystrixCommand(fallbackMethod="process_Hystrix_GET")
public Dept get(@PathVariable("id")Integer id){
Dept dept= deptService.get(id);
System.err.println(dept);
if(dept==null){
throw new RuntimeCryptoException("id:"+id+"没有改信息");
}
return dept;
}
public Dept process_Hystrix_GET(Integer id){
Dept dept=new Dept();
dept.setId(id);
dept.setDbSource("no DbSource");
dept.setName("@Hystrix");
return dept;
}
在启动类上添加@EnableCircuitBreaker注解
- 服务降级
上诉方法会引发一个问题,就是每一个方法上面都要有@HystrixCommand()注解及一个fallback方法,这样会造成方法膨胀,耦合度较高。这时候想到Spring中的异常通知,进行解耦。服务降级是配置在客户端的,配置如下:
自顶一个实现FallbackFactory接口,注意这个类要加@Component注解
@Component
public class DeptClientServiceFallbackFactory implements FallbackFactory<DeptClientService>{
@Override
public DeptClientService create(Throwable arg0) {
return new DeptClientService() {
@Override
public List<Dept> list() {
// TODO Auto-generated method stub
return null;
}
@Override
public Dept get(Integer id) {
Dept dept=new Dept();
dept.setId(id);
dept.setDbSource("no DbSource");
dept.setName("@Hystrix");
return dept;
}
@Override
public void add(Dept dept) {
// TODO Auto-generated method stub
}
};
}
}
接口代码
@FeignClient(value="MICROSERVICECLOUD-DEPT",fallbackFactory=DeptClientServiceFallbackFactory.class)
public interface DeptClientService {
@GetMapping(value="/dept/get/{id}")
public Dept get(@PathVariable("id")Integer id);
@PostMapping("/dept/add")
public void add(Dept dept);
@GetMapping(value="/dept/list")
public List<Dept> list();
}
服务端工程的yml文件中添加:
feign:
hystrix:
enabled: true