注意:这里用到的项目都是在之前几篇文章讲解用到的项目工程基础上进行的,在这一系列博客写完后会提供源码地址。
项目源码及相关说明请查看此文:Spring Cloud入门教程-简介
这里说一下熔断器,开始之前先了解两个概念:
1.什么是Hystrix?
在分布式系统中,服务与服务之间的依赖错综复杂,一种不可避免的情况就是某些服务会出现故障,导致依赖于它们的其他服务出现远程调度的线程阻塞。 Hystrix是 Netflix公司开源的一个项目,它提供了熔断器功能,能够阻止分布式系统中出现联动故障。 Hystrix是通过隔离服务的访问点阻止联动故障的,并提供了故障的解决方案,从而提高了整个分布式系统的弹性。
2.雪崩效应
在高并发的情况下,单个服务的延迟会导致整个请求都处于延迟状态,可能在几秒钟就使整个服务处于线程负载饱和的状态。某个服务的单个点的请求故障会导致用户的请求处于阻塞状态,最终的结果就是整个服务线资源消耗尽,由于服务的依赖性,会导致依赖于该故障服务的其他服务也处于线程阻塞,整最终导致这些服务的线程资源消耗殆尽,直到不可用,从而导致整个服务系统不可用,即雪崩效应。
为了防止雪崩效应,因而产生了熔断器模型。 Hystrix是在业界表现非常好的一个熔断器模型实现的开源组件,它是 Spring Cloud组件不可缺少的一部分。
Hystrix的设计原则:
a.防止单个服务的故障耗尽整个服务的Seet容器(例如 Tomcat)的线程资源
b.快速失败机制,如果某个服务出现了故障,则调用该服务的请求快速失败,而不是线程等待。
c.提供回退( fallback)方案,在请求发生故障时,提供设定好的回退方案。
d.使用熔断机制,防止故障扩散到其他服务。
e.提供熔断器的监控组件 Hystriⅸ Dashboard,可以实时监控熔断器的状态。
怎样在RestTemp 上使用熔断器
在之前的eureka-client-ribbon 项目上进行改造:
首先增加依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
在启动类EurekaClientRibbonApplication上添加@EnableHystrix注解
@EnableHystrix
@EnableEurekaClient
@SpringBootApplication
@ComponentScan("com.springcloud.demo.eurekaclientribbon")
public class EurekaClientRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaClientRibbonApplication.class, args);
}
}
修改RibbonService 在main()方法上添加@HystrixCommand
@Service
public class RibbonService {
@Autowired
RestTemplate restTemplate;
@HystrixCommand(fallbackMethod = "errorFallbackMsg")
public int main(){
return restTemplate.getForObject("http://eureka-client/main",Integer.class);
}
public int errorFallbackMsg(){
return -2;
}
}
fallbackMethod参数是在熔断器打开时,即远程服务调用失败时执行的方法名。
启动eureka-client-ribbon ,关闭两个eureka-client 实例,请求http://localhost:8795/main
返回-2,熔断器生效。
在Feign上使用熔断器
添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
在老版本中 由于feign 中使用了hytrix,因此不需要加入依赖,但是新版本中会报错找不到类
Caused by: java.lang.ClassNotFoundException: com.netflix.hystrix.contrib.javanica.aop.aspectj.HystrixCommandAspect
添加配置
eign.hystrix.enabled=true
开启Hytrix 功能。
修改FeignService,添加参数fallback。
@FeignClient(value = "eureka-client", configuration = FeignConfig.class,fallback = MainHystrixError.class)
public interface FeignService {
@GetMapping("main")
int main();
}
创建熔断器逻辑处理类MainHystrixError,当请求远程服务失败时执行。
@Component
public class MainHystrixError implements FeignService {
@Override
public int main() {
return -1;
}
}
关闭两个eureka-client 实例,启动eureka-client-feign,请求:http://localhost:8794/main 返回-1,说明熔断器功能开启。