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

  1. 服务熔断

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

  1. 服务降级
    上诉方法会引发一个问题,就是每一个方法上面都要有@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
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值