Spring Cloud实战(三):微服务错误处理与延迟处理-Hystrix
来源:互联网 发布:英雄联盟网络监控 编辑:程序博客网 时间:2024/06/18 17:29
Hystrix是为了提高微服务的健壮性而生的,它能起到如下作用:
1. 控制与保护微服务的延迟与失败问题,尤其是通过网络访问依赖的微服务导致的延迟与错误传播问题;
2. 阻止连锁的服务调用失败问题;
3. 快速失败与快速恢复;
4. 优雅的降级(降低服务质量)与反馈;
5. 实时监控、告警与控制;
简单点说,因为一个用户请求需要调用多个微服务,那么只要有一个微服务出现问题,那么整个请求都必然受到影响,这也是短板效应,Hystrix就是为了尽可能将这种影响降到最低(不可能消除)。
1. 错误处理
为了降低业务密集性的服务受到影响,我们有必要为此服务提供备用处理手段,这也是Hystrix最常用的应用场景,具体应用步骤如下:
- 在Spring Boot程序中启用@EnableCircuitBreaker注解,如下:
@EnableEurekaClient@EnableCircuitBreaker@SpringBootApplication@Import({ServiceConfigs.class, MvcConfigs.class})public class MiranaAssetApplication extends SpringBootServletInitializer { /** * 添加自身的配置信息 * @param application * @return */ @Override protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { return application.sources(MiranaAssetApplication.class); } public static void main(String[] args) { SpringApplication.run(MiranaAssetApplication.class, args); }}
- 在微服务端(Eureka客户端)添加Hystrix依赖如下:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId></dependency>
- 在服务接口上添加HystrixCommand注解,并指向备份方法,如下:
@Override@HystrixCommand(fallbackMethod = "findAllDefault")public List<Asset> findAll() { throw new RuntimeException("内部错误");}/** * 备份的处理方法 */public List<Asset> findAllDefault() { return assets.values().asList();}
现在如果测试我们的Controller,你会发现,调用findAll方法虽然失败了,但是会返回findAllDefault方法的执行结构。
2. 延时处理
如果任务的耗时较长,例如上述代码的finfAll()方法耗时十秒,那么也会自动切换到备份的处理方法,如下:
@HystrixCommand(fallbackMethod = "findAllDefault")public List<Asset> findAll() { try { // 自动进行超时处理 Thread.sleep(10000); } catch (InterruptedException e) { e.printStackTrace(); } return null;}
在异常处理中,除了支持同步调用,还是异步调用Future
响应式任务
参考文档
- Hystrix wiki
- hystrix-javanica
- 应对复杂分布式系统中的延时和故障容错
阅读全文
0 0
- Spring Cloud实战(三):微服务错误处理与延迟处理-Hystrix
- Spring Cloud实战(四):微服务质量监控-Hystrix仪表盘
- 微服务框架Spring Cloud: 在微服务系统中使用Hystrix, Hystrix Dashboard与Turbine
- Spring Cloud中Hystrix的服务降级与异常处理
- spring cloud实现微服务容错处理
- 微服务框架Spring Cloud介绍 Part5: 在微服务系统中使用Hystrix, Hystrix Dashboard与Turbine
- 微服务框架Spring Cloud介绍 Part5: 在微服务系统中使用Hystrix, Hystrix Dashboard与Turbine
- Spring Cloud微服务断路由Hystrix与服务网关学习笔记
- Spring Cloud微服务断路由Hystrix与服务网关学习笔记
- Spring Cloud微服务(5)之Hystrix断路器
- Spring Cloud入门教程(四):微服务容错保护(Hystrix)
- Spring Cloud构建微服务架构:Hystrix监控面板
- Spring Cloud构建微服务架构:Hystrix监控数据聚合
- Spring Cloud构建微服务架构Hystrix依赖隔离
- Spring Cloud构建微服务架构—Hystrix断路器
- Spring Cloud构建微服务架构Hystrix监控面板
- Spring Cloud构建微服务架构Hystrix依赖隔离
- Spring Cloud构建微服务架构Hystrix监控面板
- 自定义view实现分享,好友位置,评论,红包,加载提示,支付成功提示,帐号冻结提示
- Redis集群搭建
- 分析JZ2440的Uboot的配置和编译过程
- 套接口类 个人笔记
- 达内课程-字符串相关方法(下)
- Spring Cloud实战(三):微服务错误处理与延迟处理-Hystrix
- 听课笔记(第一讲):台湾国立大学的《机器学习基石》(Coursera 版)
- JSP(3)脚本、注释、指令
- 【C++】new和delete隐藏的秘密!!!
- 《C++ Primer》读书笔记第七章-2-类的其他特性 And 类的作用域
- 说是
- 引用和指针的区别
- 海康2017校招C++开发岗位笔试题
- CCF_201609_火车购票(超漂亮的做法)