Springcloud 服务熔断和服务降级配置

  1. 服务熔断

概念:微服务中,熔断机制是应对雪崩效应的一种微服务链路保护机制。当扇出链路的某个微服务不可用或者响应时间太长时,会进行服务降级,进而熔断该节点微服务的调用,快速返回“错误”的响应信息。当检测到该节点微服务调用响应正常后恢复调用链路。
服务熔断的作用类似于我们家用的保险丝,当某服务出现不可用或响应超时的情况时,为了防止整个系统出现雪崩,暂时停止对该服务的调用。
服务熔断是在服务端进行配置的,配置如下:
在pom.xml引入hystrix依赖


  org.springframework.cloud
    spring-cloud-starter-hystrix
    1.4.7.RELEASE

在方法上添加注解@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注解

  1. 服务降级
    上诉方法会引发一个问题,就是每一个方法上面都要有@HystrixCommand()注解及一个fallback方法,这样会造成方法膨胀,耦合度较高。这时候想到Spring中的异常通知,进行解耦。服务降级是配置在客户端的,配置如下:
    自顶一个实现FallbackFactory接口,注意这个类要加@Component注解
@Component
public class DeptClientServiceFallbackFactory implements FallbackFactory{

	@Override
	public DeptClientService create(Throwable arg0) {
		return new DeptClientService() {
			
			@Override
			public List 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 list();
}

服务端工程的yml文件中添加:

feign:
  hystrix:
    enabled: true

你可能感兴趣的:(JAVA,EE)