博客
关于我
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/

你可能感兴趣的文章
nginx启动脚本
查看>>
Nginx在Windows上和Linux上(Docker启动)分别配置基本身份认证示例
查看>>
Nginx在Windows下载安装启动与配置前后端请求代理
查看>>
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>
Nginx学习总结(12)——Nginx各项配置总结
查看>>
Nginx学习总结(13)——Nginx 重要知识点回顾
查看>>
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
nginx学习笔记002---Nginx代理配置_案例1_实现了对前端代码的方向代理_并且配置了后端api接口的访问地址
查看>>
Nginx安装与常见命令
查看>>
Nginx安装及配置详解
查看>>
nginx安装配置
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
Nginx实现反向代理负载均衡
查看>>
nginx实现负载均衡
查看>>
nginx常用命令及简单配置
查看>>
Nginx常用屏蔽规则,让网站更安全
查看>>
nginx开机启动脚本
查看>>
nginx异常:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf
查看>>
nginx总结及使用Docker创建nginx教程
查看>>