博客
关于我
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分组函数
查看>>
MySQL分组查询
查看>>
Mysql分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
查看>>
mySql分页Iimit优化
查看>>
MySQL分页查询
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>