从永远到永远-SpringCloud项目实战(七)-Hystrix及spring cloud服务见调用的过程

本文详细介绍了Spring Cloud服务间调用流程中Hystrix的熔断处理机制,包括Feign请求转换、HystrixCommand包装、Ribbon服务选择及HttpClient调用等关键步骤,同时提供了Hystrix的使用步骤。

关于Hystrix
下图为Spring Cloud服务间调用的基本流程,面试爱问!房子啊这里,帮助理解Hystrix
在这里插入图片描述
(1)接口化请求调用当调用被@FeignClient注解修饰的接口时,在框架内部,将请求转换成Feign的请求实例feign.Request,交由Feign框架处理。
(2)Feign :转化请求Feign是一个http请求调用的轻量级框架,可以以Java接口注解的方式调用Http请求,封装了Http调用流程。

(3)Hystrix:熔断处理机制 Feign的调用关系,会被Hystrix代理拦截,对每一个Feign调用请求,Hystrix都会将其包装成HystrixCommand,参与Hystrix的流控和熔断规则。如果请求判断需要熔断,则Hystrix直接熔断,抛出异常或者使用FallbackFactory返回熔断Fallback结果;如果通过,则将调用请求传递给Ribbon组件。

(4)Ribbon:服务地址选择 当请求传递到Ribbon之后,Ribbon会根据自身维护的服务列表,根据服务的服务质量,如平均响应时间,Load等,结合特定的规则,从列表中挑选合适的服务实例,选择好机器之后,然后将机器实例的信息请求传递给Http Client客户端,HttpClient客户端来执行真正的Http接口调用;

(5)HttpClient :Http客户端,真正执行Http调用根据上层Ribbon传递过来的请求,已经指定了服务地址,则HttpClient开始执行真正的Http请求

1、Hystrix的使用

1、引入依赖

<!--hystrix依赖,主要是用  @HystrixCommand -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

这里只有些hystrix的依赖,但是通常其是与ribbon 和feign一起用的。注意那两个的依赖,我额外已经引入了。

2、调用端(消费者)的配置文件中开启熔断机制
在这里插入图片描述

3、创建实现类,实现接口。(此接口是Feign调用其他服务时写的接口)

/**
 * @program: education
 * @description:
 * @author: WL
 * @create: 2020-06-22 17:10
 **/
@Component
public class VodFileDegradeFeignClient implements VodClient {
	@Override
	public R removeAliYunVideo(String id) {
		return R.error().message("删除视频出错!");
	}

	@Override
	public R deleteBatch(List<String> videoList) {
		return R.error().message("批量删除视频出错!");
	}
}

4、改造FeignClient接口,在注解中指定实现类。如果Feign调用接口出错,则执行指定的实现类中的方法。
在这里插入图片描述
5、根据实际内容调整业务代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值