`
chengpeng_2015
  • 浏览: 6820 次
社区版块
存档分类
最新评论

SpringCloud服务熔断及降级Hystrix(四)

阅读更多

1.服务熔断

当Hystrix Command请求后端服务失败数量超过一定比例(默认50%), 断路器会切换到开路状态(Open). 这时所有请求会直接失败而不会发送到后端服务. 断路器保持在开路状态一段时间后(默认5秒), 自动切换到半开路状态(HALF-OPEN).

这时会判断下一次请求的返回情况, 如果请求成功, 断路器切回闭路状态(CLOSED), 否则重新切换到开路状态(OPEN). Hystrix的断路器就像我们家庭电路中的保险丝, 一旦后端服务不可用, 断路器会直接切断请求链, 避免发送大量无效请求影响系统吞吐量, 并且断路器有自我检测并恢复的能力.

2.服务降级

Fallback相当于是降级操作. 对于查询操作, 我们可以实现一个fallback方法, 当请求后端服务出现异常的时候, 可以使用fallback方法返回的值. fallback方法的返回值一般是设置的默认值或者来自缓存.告知后面的请求服务不可用了,不要再来了。

2.1调用方的服务降级

2.1.1在consumer项目添加hystrix依赖

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
  4. </dependency>

2.1.1在consumer项目controller添加测试方法

  1. @RequestMapping("/testHystrix")
  2. @HystrixCommand(fallbackMethod="hystrixFallbackMethod",commandKey="provider")
  3. public String testHystrix(){
  4. String result = providerService.providerReuslt();
  5. return "testHystrix result="+result;
  6. }
  7. public String hystrixFallbackMethod(){
  8. return "hystrixFallbackMethod invoker.";
  9. }

2.1.3在consumer启动主类添加启动hystrix的注解

  1. @EnableHystrix

2.1.4启动测试

启动注册中心及consumer访问 
http://127.0.0.1:30010/testHystrix

2.2服务方的服务降级

2.2.1添加服务接口回调类

  1. @Component
  2. public class ProviderServiceFallback implements ProviderService{
  3. @Override
  4. public String providerReuslt(){
  5. return "ProviderServiceFallback invoker~!";
  6. }
  7. }

2.2.2在服务接口上指定回调类

@FeignClient(value=”provider”, fallback=ProviderServiceFallback.class/**针对接口设置错误回调,如果和@HystrixCommand同时存在则先执行这里*/)

2.2.3在配置文件开启feign的hystrix特性

  1. #开启feign的熔断降级机制
  2. feign:
  3. hystrix:
  4. enabled: true

2.2.4启动测试

依次启动注册中心和consumer再次访问 
http://127.0.0.1:30010/testHystrix

分享到:
评论

相关推荐

    springcloud熔断降级组件hystrix详解.part2.rar

    springcloud熔断降级组件hystrix详解代码练习,由于平台上传限制,所以分为了两个部分上传。此为第二部分。 第一部分为:https://download.csdn.net/download/keenstyle/12232188

    springcloud熔断降级组件hystrix详解.part1.rar

    springcloud熔断降级组件hystrix详解代码练习,由于平台上传限制,所以分为了两个部分上传。此为第一部分。 第二部分:https://download.csdn.net/download/keenstyle/12232210

    spring cloud hystrix原理介绍及使用

    spring cloud hystrix通过服务隔离、熔断、降级等手段控制依赖服务的延迟与失败。

    springCloud_hystrix(断路由服务降级)

    断路由出现的原因是: 在微服务架构中,我们将业务拆分成一个个的服务,服务与服务之间可以相互调用(RPC)。为了保证其高可用,单个服务又必须集群部署。...为了解决这个问题,就出现断路器模型,把服务进行降级处理。

    SpringCloud微服务框架学习源码

    内容包括Eureka服务的注册发现及Eureka集群的实现、客户端负载均衡Ribbon、接口式负载均衡Feign、服务熔断与服务降级Hystrix、Hystrix dashboard断路器监控、统一路由网关Zuul配置、springcloud config分布式远程...

    尚硅谷SpringCloud视频(最新)

    41.尚硅谷_SpringCloud_服务降级熔断小总结 42.尚硅谷_SpringCloud_豪猪hystrixDashboard 43.尚硅谷_SpringCloud_如何查看hystrixDashboard 44.尚硅谷_SpringCloud_Zuul是什么 45.尚硅谷_SpringCloud_Zuul路由基本...

    微服务springcloud之feign和hystrix使用demo

    feign中包含了hystrix以及ribbon,即feign在不导入hystrix和ribbon的依赖下也能完成他们所能实现的功能,当然,如果想使用hystrix和ribbon自带的注解以及配置,必须导入依赖才可以,feign结合hystrix实现熔断+降级,...

    想学习的看过来了spring4.0、springboot、springcloud详细视频课程(硅谷)

    41.硅谷学习_SpringCloud_服务降级熔断小总结 42.硅谷学习_SpringCloud_豪猪hystrixDashboard 43.硅谷学习_SpringCloud_如何查看hystrixDashboard 44.硅谷学习_SpringCloud_Zuul是什么 45.硅谷学习_SpringCloud_...

    SpringCloud微服务架构Demo案例

    涉及到Eureka集群的配置、Ribbon的自定义负载均衡、Feign的声明式接口调用、Hystrix的服务熔断和降级、Zuul的Api GateWay网关和SpringCloud Config 的动态配置中心。SpringCloud的技术栈21种之多,这里只是使用到了...

    尚硅谷Java视频教程_SpringCloud视频教程

    41.尚硅谷_SpringCloud_服务降级熔断小总结 42.尚硅谷_SpringCloud_豪猪hystrixDashboard 43.尚硅谷_SpringCloud_如何查看hystrixDashboard 44.尚硅谷_SpringCloud_Zuul是什么 45.尚硅谷_SpringCloud_Zuul路由...

    SpringCloud H版+SpringCloud alibaba

    重点讲解了SpringCloud各种组件停止更新进入维护阶段后,后续技术组件的升级和替换策略及方案选型,既有传统Eureka、Ribbon、OpenFeign、Hystrix、Config等技术的升级讲解,又有Consul、Gateway、Bus、Stream、Sleuth...

    新版本SpringCloud2学习手册

    服务保护机制SpringCloud Hystrix 33 微服务高可用技术 33 服务降级、熔断、限流概念 34 服务学崩效应 34 服务降级 34 服务熔断 35 服务隔离 35 服务限流 36 Hystrix简单介绍 36 Hystrix环境搭建 37 Maven...

    springcloud整合Hystrix.7z

    springcloud整合Hystrix源码。入门级。主要是用来弄明白断路器。服务熔断、服务降级。为以后提供参考

    Spring Cloud 阶段性开发与测试

    005-接入Hystrix断路器,实现服务的熔断与降级; 006-接入Hystrix-Dashboard,实现微服务监控; 007-接入zuul,实现服务的代理、路由、过滤; 008-接入config,实现服务端的配置; 009-接入config,实现客户端的配置...

    springcloud研究报告.docx

    本文实践了SpringCloud的核心功能,包括基于Eureka实现了服务注册和发现,基于Ribbon实现了客户端负载均衡的Rest远程调用,基于Hystrix实现了请求熔断,服务降级。可以作为一篇详细的springcloud快速上手图文教程。

    spingcloud整合eureka、 Hystrix断路器的降级、熔断、服务监控图形.zip

    Hystrix是一个库,通过添加延迟容忍和容错逻辑,帮助你控制这些分布式服务之间的交互。Hystrix通过隔离服务之间的访问点、停止级联失败和提供回退选项来实现这一点,所有这些都可以提高系统的整体弹性。复杂分布式...

    史上最全SpringCloud微服务视频教程教程

    详细讲解  微服务技术架构概述 ...服务调用工具rest与fegin SpringCloud调用服务原理剖析 SpringCloud实现服务负载均衡原理 使用ribbon客户端实现负载均衡 ...使用hystrix实现服务降级、熔断机制、解决雪崩效应

    Spring cloud.zip

    SpringCloud_Eureka(注册中心)_restTemplate+Ribben(负载均衡)_Feign(负载均衡)_Hystrix(断路器)_Hystrix DashBoard(可视化服务监控)_Zuul(路由网关)_SpringCloud Config(分布式配置中心) restTemplate:...

    hystrix.rar

    spring boot+openfeign+hystrix实现springcloud微服务的熔断和降级

    SpringCloudHystrixTurbin

    包含两个可以单独运行的程序,一个SpringCloudHystrix,简单示例调用远程服务的断路功能;一个SpringCloudTurbin,简单展示与Eureka分离,配置hystrix的集群监控功能;更多示例,可参考本人上传的其他资源。

Global site tag (gtag.js) - Google Analytics