博客
关于我
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查询报错ERROR:No query specified
查看>>
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
MySQL模拟Oracle序列sequence
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>