博客
关于我
SpringCloud-组件服务熔断Hystrix和声明式服务消费Feign
阅读量:516 次
发布时间:2019-03-07

本文共 1369 字,大约阅读时间需要 4 分钟。

一、什么是Hystrix?

Hystrix叫做熔断器也称为断路器,微服务架构中的熔断器就是当被调用方没有响应时,调用方直接返回一个错误响应即可,而不是长时间的等待,这样避免调用时因为等待而现场一直得不到释放,避免故障在分布式系统间蔓延。

例如: 电商平台中用户下单,我们一个是订单服务,一个是减库存服务,当用户下订单时调用下订单服务,然后下订单服务又调用减库存服务,如果减库存服务响应延迟或者没有响应,则会造成下订单服务的线程挂起等待,如果大量的用户请求下订单,出现大量请求堆积,引起下订单服务也不可用,或者下订单服务还需要提供给其它服务来进行使用,这就造成了整个微服务出现瘫痪的情况。

二、Hystrix在项目中的使用

在入口类中使用@enableCircuitBreaker注解开启断路器功能,也可以使用 @SpringCloudApplication注解代替我们主类上的三个注解。

@HystrixCommand(fallbackMethod="error", commandProperties={	@HystrixProperty(name="execution.isolation.thread.timeoutInMilliseconds", value="1500")}) //熔断器,调用不通,回调 error()方法

fallbackMethod 整个参数就是制定服务不可用是回调的方法;

三、Hystrix的服务降级

有了服务的熔断后,随之就会有服务的降级,所谓服务的降级,就是当某个服务熔断之后,服务端提供的服务将不再调用,此时有客户端自己来准备一个本地的fallback回调,返回一个默认值来代表服务端的返回。

四、Hystrix的异常处理

我们在调用服务提供者时,我们自己也有可能会抛异常,默认情况下抛出的异常会自动进行服务降级,交给服务降级中的方法区处理;

public String error(Throwable throwable) {	 System.out.println(throwable.getMessage()); return "error"; }

五、声明式服务消费Feign

Feign是整合了 Ribbon和Hystrix两个组件。这种整合犹如SpringBoot 对Spring 和SpringMVC的整合一样。大大简化服务调用的流程。

@EnableFeignClients 表示开启对SpringCloud Feign的支持

@FeignClient注解来指定服务名称,进而绑定服务,然后再通过SpringMVC中提供的注解来绑定服务提供者提供的接口

举个例子:

@FeignClient("01-springcloud-service-provider")	public interface HelloService {	 @RequestMapping("/service/hello")	 public String hello();}

这里就相当于绑定了一个名叫01-springcloud-service-provider

属性配置:

#配置服务的名称...spring.application.name=05-springcloud-service-feign...

转载地址:http://knunz.baihongyu.com/

你可能感兴趣的文章
Mysql索引(4):索引语法
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql练习语句
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql编写存储过程
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql联合索引 where_mysql联合索引与Where子句优化浅析
查看>>
mysql联合索引的最左前缀匹配原则
查看>>
MySQL聚簇索引
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>
Mysql自增id理解
查看>>
mysql自增id超大问题查询
查看>>
MySQL自定义变量?学不废不收费
查看>>
MySQL自带information_schema数据库使用
查看>>
MySQL获取分组后的TOP 1和TOP N记录
查看>>