一、为什么要有熔断
在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的 “雪崩” 效应。
为了解决这个问题,业界提出了断路器模型 。 以上出自:https://blog.csdn.net/forezp/article/details/81040990
二、熔断实现
1. 首先 启动 注册中心 eureka 工程、服务生产者 see-param 工程(8803端口)、
服务消费者 feign 工程(8702端口)、服务消费者 ribbon 工程(8701 端口)。
(生产者和消费者这 2 个概念是相对的。在不同的业务场景中,2 者身份可互换。或多服务时,同一服务可兼具 2 个身份。)
分别访问 生产者:
2. feign 中熔断器实现。
配置文件中开启熔断:
# 开启断熔器: ( Feign 自带断路器,但默认为不开启: false)
feign.hystrix.enabled=true
在 SeeParamService 类中 @FeignClient 注解中加上参数 fallback ,并指明熔断方法实现类。
书写 熔断方法实现类:
package com.feign.servicefeign;
import org.springframework.stereotype.Component;
/**
* @author yujiang
* @description 迷断回调方法类
* @date 2019/7/24 9:39
*/
// 注入IOC容器中,把本类交给 spring 管理
@Component
public class SeeParamError implements SeeParamService {
@Override
public String seeParam(String param) {
return " 乖乖加班吧,服务挂了,搬砖,搬砖 ... ";
}
}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,feign 熔断生效 。
3. ribbon 中熔断器实现。
ribbon 并不自带迷断功能,故要引入依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
工程启动类加注解 @EnableHystrix ,开启熔断。
SeeParamService 类中,在要实现熔断的方法上加注解:@HystrixCommand(fallbackMethod = "熔断实现方法名"),如:
package com.ribbon.serviceribbon;
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;
/**
* @author yujiang
* @description
* @date 2019/7/22 11:45
*/
@Service
public class SeeParamService {
@Autowired
RestTemplate restTemplate;
/**
* 注解 @HystrixCommand :
* 开启熔断器,指定熔断时回调方法为 seeParamError
*
* @param param
* @return
*/
@HystrixCommand(fallbackMethod = "seeParamError")
public String seeService(String param) {
return restTemplate.getForObject("http://see-param/seeParam?param=" + param, String.class);
}
/**
* 熔断 调用此方法
*
* @return
*/
public String seeParamError(String param) {
return " 哎,别瞅了,别瞅了,服务已经 go die ...";
}
}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,ribbon 熔断生效 。