Spring Cloud Hystrix
关于Spring Cloud Hystrix的介绍可以参阅这篇博客 点击进入
还是以之前构建的项目为基础,分别启动注册中心Eureka-Server,启动两个服务的提供者,两个服务的提供者的端口号分别为8001和8002,最后再启动一个端口号9000的服务消费者。启动完成后访问localhost:1111,如下图所示,可以看到两个服务的提供者实例和一个服务的消费者实例已经被注册到了注册中心。
现在我们停掉端口号为8002的服务提供者实例,然后调用上一节中服务消费者的接口,在ribbon-consumer的控制台中可以看到如下信息。
下面要做的就是为ribbon-consumer项目引入断路器spring cloud hystrix
第一步,先在ribbon-consumer项目的pom文件中引入spring cloud hystrix的依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
第二步,在ribbon-consumer项目的启动类上加入@EnableCircuitBreaker注解,用来打开断路器功能,
第三步,改造ribbon-consumer,新增一个service类,并将之前调用服务的方法迁移到该service类中,并通过注解来使用断路器。
具体代码如下
ConsumerService
@Service
public class ConsumerService {
@Resource
RestTemplate restTemplate;
@HystrixCommand(fallbackMethod="helloHystrix")
public String helloService(){
Map<String,String> params = new HashMap<>();
params.put("name","xg");
params.put("sex","male");
return restTemplate.getForEntity("http://eureka-service/hello?name={name}&sex={sex}", String.class, params).getBody();
}
public String helloHystrix(){
return "error";
}
}
ConsumerController
@RestController
public class ConsumerController {
@Autowired
ConsumerService consumerService;
@RequestMapping(value="/ribbon-consumer",method = RequestMethod.GET)
@ResponseBody
public String helloConsumer(){
return consumerService.helloService();
}
}
到现在,入门案例就已经搭建好了,所以下面要做的就是测试一下hystrix到底有没有生效。与开始时相同,停掉一个服务提供者的实例,访问ribbon-consumer提供的接口
输出的是error,而不是之前的报错信息,断路器已经生效。