博客
关于我
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 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>
Mysql 知识回顾总结-索引
查看>>
Mysql 笔记
查看>>
MySQL 精选 60 道面试题(含答案)
查看>>