博客
关于我
SpringCloud-组件服务熔断Hystrix和声明式服务消费Feign
阅读量:516 次
发布时间:2019-03-07

本文共 946 字,大约阅读时间需要 3 分钟。

什么是Hystrix?

在分布式系统中,当一个服务无法响应时,直接返回错误响应而不是长时间等待,以防止故障在系统间蔓延。以电商平台为例,订单服务和减库存服务互相调用,当减库存服务出现延迟或不可用时,订单服务不会一直等待,避免影响整体系统的稳定性。

Hystrix在项目中的使用

在入口类使用@enableCircuitBreaker注解开启断路器功能,可以通过@SpringCloudApplication注解替代主类注解。使用@HystrixCommand注解指定回调方法,例如:

@HystrixCommand(fallbackMethod = "error", commandProperties = {    @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1500")})

fallbackMethod指定服务不可用时回调的方法。

服务降级

熔断后,服务降级生效,客户端返回默认值。例如,服务提供者不可用时,客户端调用本地回调方法返回默认值。

异常处理

在调用服务提供者时,抛出的异常会触发服务降级机制,交给指定的回调方法处理,如:

public String error(Throwable throwable) {    System.out.println(throwable.getMessage());    return "error";}

Feign集成

Feign整合Ribbon和Hystrix,大大简化了服务调用流程。配置@EnableFeignClients开启支持,使用@FeignClient注解指定服务名称并绑定接口:

@FeignClient("01-springcloud-service-provider")public interface HelloService {    @RequestMapping("/service/hello")    public String hello();}

通过spring.application.name属性配置服务名称,将Feign与SpringMVC整合,实现高效服务调调用。

转载地址:http://knunz.baihongyu.com/

你可能感兴趣的文章
OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
查看>>
OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
查看>>
OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
查看>>
OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
查看>>
oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
查看>>
OAuth2:项目演示-模拟微信授权登录京东
查看>>
OA系统多少钱?OA办公系统中的价格选型
查看>>
OA系统选型:选择好的工作流引擎
查看>>
OA项目之我的会议(会议排座&送审)
查看>>
OA项目之我的会议(查询)
查看>>
Object c将一个double值转换为时间格式
查看>>
object detection训练自己数据
查看>>
object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
查看>>
object detection错误之no module named nets
查看>>
Object of type 'ndarray' is not JSON serializable
查看>>
Object Oriented Programming in JavaScript
查看>>
object references an unsaved transient instance - save the transient instance before flushing
查看>>
Object.keys()的详解和用法
查看>>
OBJECTIVE C (XCODE) 绘图功能简介(转载)
查看>>
Objective-C ---JSON 解析 和 KVC
查看>>